2200
How can I delete the selected items (including descendants)

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="KeyDown(KeyCode,Shift)" LANGUAGE="JScript">
	G2antt1.RemoveSelection();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.SingleSel = false;
	G2antt1.Columns.Add("Tasks");
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "8/1/2017";
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(false) = 128;
		var_Chart.SelBackColor = 15790320;
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem("Task 1"),"Task","8/2/2017","8/6/2017",null,null);
		var h = var_Items.AddItem("Task 2");
		var_Items.AddBar(h,"Task","8/3/2017","8/9/2017",null,null);
		var_Items.SelectItem(h) = true;
		h = var_Items.AddItem("Task 3");
		var_Items.AddBar(h,"Task","8/4/2017","8/13/2017","",null);
		var_Items.SelectItem(h) = true;
		var_Items.AddBar(var_Items.AddItem("Task 4"),"Task","8/5/2017","8/16/2017",null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2199
Dark mode

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var back = 65536;
	var fore = 16777215;
	G2antt1.VisualAppearance.Add(1,"gBFLBCJwBAEHhEJAAEhABXUIQAAYAQGKIcBiAKBQAGYBIJDEMgzDDAUBjKKocQTC4AIQjCK4JDKHYJRpHEZyCA8EhqGASRAFUQBYiWE4oSpLABQaK0ZwIGyRIrkGQgQ" +
	"gmPYDSDNU4zVIEEglBI0TDNczhNDENgtGYaJqHIYpZBcM40TKkEZoSIITZcRrOEBiRL1S0RBhGcRUHZlWzdN64LhuK47UrWdD/XhdVzXRbjfz1Oq+bxve48Br7A5yYTh" +
	"dr4LhOFQ3RjIL4xbIcUwGe6VZhjOLZXjmO49T69HTtOCYBEBA");
	G2antt1.VisualAppearance.Add(2,"gBFLBCJwBAEHhEJAAEhABPMIQAAYAQGKIcBiAKBQAGaAoDDcMgwQwAAxjIKUEwsACEIrjKCYVgOHYYQjGMZwHCMIhiGwcAChEZYHgkMYmDAMUhSE78axHG6PY7kKZ4b" +
	"iaKIqQLLEhSfJ0YyBECBZpfebIbjmIZMSLEIxDKItJSpCIaRgqWS6ahGO4JUbUFLQHT9IR4daIYRgEEBA");
	G2antt1.VisualAppearance.Add(3,"gBFLBCJwBAEHhEJAAEhABUUIQAAYAQGKIcBiAKBQAGaAoDDcMgwQwAAxjIKUEwsACEIrjKCYVgOHYYQjGMZwGAsEwjAoYAChEaILgkMw2DBIQwgJIMEr/G6RZxjeL5C" +
	"jmG4nDhKMpybAcXxjBIYZJgOQpXb+PobTrNNLzfRFAxVAaWJikcZ4HpIAJNVLFdQ0XYMNSBISsBqrKiKcpeIIDWBZMbRZT1ZABCIZBpEW6LahENQwXrCN74DYkNTdKax" +
	"bbuaaXLhGCYBgIA==");
	G2antt1.HeaderAppearance = 5;
	G2antt1.BackColor = back;
	G2antt1.BackColorHeader = back;
	G2antt1.BackColorLevelHeader = back;
	G2antt1.BackColorSortBar = back;
	G2antt1.BackColorSortBarCaption = back;
	G2antt1.FilterBarBackColor = back;
	G2antt1.FilterBarForeColor = fore;
	G2antt1.ForeColor = fore;
	G2antt1.ForeColorHeader = fore;
	G2antt1.ForeColorSortBar = fore;
	G2antt1.SelBackColor = fore;
	G2antt1.SelForeColor = back;
	G2antt1.Background(0) = 16777216;
	G2antt1.Background(18) = 33554432;
	G2antt1.Background(32) = -1;
	G2antt1.Background(64) = 50331648;
	G2antt1.Background(65) = back;
	G2antt1.Background(66) = fore;
	G2antt1.Background(20) = fore;
	G2antt1.Background(21) = back;
	G2antt1.Background(26) = back;
	G2antt1.Background(27) = fore;
	G2antt1.Background(28) = back;
	G2antt1.Background(142) = 33554432;
	G2antt1.Background(141) = 33554432;
	G2antt1.Background(186) = fore;
	G2antt1.Background(511) = back;
	G2antt1.Description(25) = "<bgcolor 0><fgcolor ffffff> Exclude </fgcolor></bgcolor>";
	var var_Chart = G2antt1.Chart;
		var_Chart.BackColor = back;
		var_Chart.BackColorLevelHeader = back;
		var_Chart.ForeColor = fore;
		var_Chart.ForeColorLevelHeader = fore;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2198
I have changed the font, but the item's height remains the same. What I am doing wrong

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.ColumnAutoResize = false;
	G2antt1.LoadXML("http://www.exontrol.net/testing.xml");
	G2antt1.Font.Size = 22;
	G2antt1.HeaderHeight = 42;
	G2antt1.DefaultItemHeight = 36;
	G2antt1.Items.ItemHeight(0) = G2antt1.DefaultItemHeight;
	G2antt1.Chart.UnitWidth = G2antt1.DefaultItemHeight;
	G2antt1.Chart.UnitScale = G2antt1.Chart.UnitScale;
	G2antt1.Chart.Bars.Item("Task").Height = 18;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2197
I have changed from Project Summary Task to own task created with EBN to get a black frame then using different colors for project status. How can I enlarge the EBN being applied to the head-arrows shows the start/end margins of the range

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="AddGroupItem(Item)" LANGUAGE="JScript">
	var var_Items = G2antt1.Items;
		var_Items.ItemBold(Item) = true;
		var_Items.AddBar(Item,var_Items.CellValue(Item,var_Items.GroupItem(Item)),"12/2/2017","12/2/2017",null,null);
		var_Items.DefineSummaryBars(Item,"",-3,"");
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="AddItem(Item)" LANGUAGE="JScript">
	G2antt1.Items.AddBar(Item,"Task","12/4/2017","12/10/2017",null,null);
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Appearance = G2antt1.VisualAppearance;
		var_Appearance.Add(1,"gBFLBCJwBAEHhEJAAEhABN0GACAADACAxRDgMQBQKAAzQFAYbBuGCGAAGIYBTgmFgAQhFcZQSKUOQTDKNYykCQBQAWCQ1DAJIqjOAkEhiGCUQClYYZBjWG4dQLOEYTN" +
	"C8WwHCIZBpEWgKChGKAlSANMjTZLkdR1ECmIhoSg4coKMoERBJco1BDdOQGAyEQShEC4fgmVwAP7aNoWVC1JynM6XaKmGbJAA6CZgQKGFh2LAdTzSf61cAtWpaUjmRZa" +
	"YSAFDxpiCYpfQjdUB2JDVfTVP6LbawS4KZgOR5eRboETYeAFcSZGrNMKEXLLSyudKRRreWQaPpGCZTRSUdZxSrbBhvEqlbRNMhwSBEEigNIxToOU4jFgeCROQwQRK9BB" +
	"oG0CQUEIdhAAyJJvjUeZdmmb5+C8HhiAeZJznoPQ+EgT4rlua4BjCfg+k8d5TkUCZ4w+fxfB+X5xn4fheGebZoH8X53koAR9CASAWAUfofjgJgKH+IJHnGcIDmER5iBE" +
	"eZgmgVgLgGYYYGoFRTCGaIGAYRYiCiFgmgmYQEF4KIKmKSBRBqCxjAiRgvgwYxIiGQYNmOCJlDUOpeAQBCAg=");
		var_Appearance.Add(2,"CP:1 -6 0 6 0");
	var var_Chart = G2antt1.Chart;
		var_Chart.LevelCount = 2;
		var_Chart.FirstVisibleDate = "12/2/2017";
		var_Chart.PaneWidth(false) = 342;
		var_Chart.Bars.Add("S1").Color = 16777216;
		var_Chart.Bars.Add("S2").Color = 50266112;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("C1");
		var_Columns.Add("C2").AllowSort = false;
	G2antt1.SingleSort = false;
	G2antt1.AllowGroupBy = true;
	G2antt1.HeaderVisible = 1;
	G2antt1.HeaderAppearance = 1;
	var var_Items = G2antt1.Items;
		var_Items.CellValue(var_Items.AddItem("S1"),1) = "SubItem A.1";
		var_Items.CellValue(var_Items.AddItem("S1"),1) = "SubItem A.1";
		var_Items.CellValue(var_Items.AddItem("S2"),1) = "SubItem B.1";
		var_Items.CellValue(var_Items.AddItem("S2"),1) = "SubItem B.1";
	G2antt1.Layout = "MultipleSort = \"C0:2\"";
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2196
How can I specify the cell's outline, border or lines around, when the cell gets selected

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.AttachTemplate("handle AddColumn(Column){Column{Def(48)=4;Def(49)=4;}}");
	var var_Appearance = G2antt1.VisualAppearance;
		var_Appearance.Add(1,"gBFLBCJwBAEHhEJAAEhABPEGACAADACAxRDgMQBQKAAzQFAYbBuGCGAAGIYBTgmFgAQhFcZQSpEEg7BKMYwjOJgFgmEQxDANIBQSKoaQiGQYYLhEZAEiONoaDJCM4wH" +
	"IMQxHCKTZRkGcfaRCGSfIzpGKpVgOTYiTbPcIyQKtBxDIydJTmeQQQhsFIJU7SdVUPDUJZlWbLAwWTAYazXCKRZBpeJqdo6Y5RUDKUqSdLUYyvEq7ZqnOIpw5vICpaCq" +
	"Op6HqKFpiXSAFL1fLmAwvPKrJjoeqpWpyCaRZQAGg4dbEdTNNCIbatQANKrCSpgZ7sMB6Di2L4TPS2awoWgRYyTFZMbBAeQ7LC1c45Fqrd4zS4dSxKCahcLxFiaNpYZY" +
	"njUap1jGPJlkuAgAkidB3nceZsCQEQJCgGhMGcQ4pkiSxEAAOYpiQIhvkYNA2gSCg5n+LIoGILowFyXQoAYAoAmASAWAaAZgggJgKF2T54DYDoDmECBGBKBJgGgTgWgW" +
	"YRoFYGIGmGOBqByB5hCgegggiYJYgoJIICIaIeByChixULILGGGAWDCCgjCiTgrg0YxojoC4OmOSJ2D6D5kAgJLFgABAEICA=");
		var_Appearance.Add(2,"CP:1 -4 0 0 0");
	G2antt1.SelBackColor = 33554432;
	G2antt1.SelForeColor = 65536;
	G2antt1.FullRowSelect = 0;
	G2antt1.ShowFocusRect = false;
	G2antt1.DefaultItemHeight = 24;
	G2antt1.HeaderHeight = 24;
	G2antt1.DrawGridLines = 2;
	G2antt1.Columns.Add("C1");
	G2antt1.Columns.Add("C2");
	var var_Items = G2antt1.Items;
		var_Items.CellValue(var_Items.AddItem("Cell 1"),1) = "Cell 2";
		var_Items.CellValue(var_Items.AddItem("Cell 3"),1) = "Cell 4";
	G2antt1.Items.SelectPos = 1;
	G2antt1.SelectColumnIndex = 1;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2195
How can I specify the cell's outline, border or lines around, when the item gets selected

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.AttachTemplate("handle AddColumn(Column){Column{Def(48)=4;Def(49)=4;}}");
	G2antt1.VisualAppearance.Add(1,"gBFLBCJwBAEHhEJAAEhABPEGACAADACAxRDgMQBQKAAzQFAYbBuGCGAAGIYBTgmFgAQhFcZQSpEEg7BKMYwjOJgFgmEQxDANIBQSKoaQiGQYYLhEZAEiONoaDJCM4wH" +
	"IMQxHCKTZRkGcfaRCGSfIzpGKpVgOTYiTbPcIyQKtBxDIydJTmeQQQhsFIJU7SdVUPDUJZlWbLAwWTAYazXCKRZBpeJqdo6Y5RUDKUqSdLUYyvEq7ZqnOIpw5vICpaCq" +
	"Op6HqKFpiXSAFL1fLmAwvPKrJjoeqpWpyCaRZQAGg4dbEdTNNCIbatQANKrCSpgZ7sMB6Di2L4TPS2awoWgRYyTFZMbBAeQ7LC1c45Fqrd4zS4dSxKCahcLxFiaNpYZY" +
	"njUap1jGPJlkuAgAkidB3nceZsCQEQJCgGhMGcQ4pkiSxEAAOYpiQIhvkYNA2gSCg5n+LIoGILowFyXQoAYAoAmASAWAaAZgggJgKF2T54DYDoDmECBGBKBJgGgTgWgW" +
	"YRoFYGIGmGOBqByB5hCgegggiYJYgoJIICIaIeByChixULILGGGAWDCCgjCiTgrg0YxojoC4OmOSJ2D6D5kAgJLFgABAEICA=");
	G2antt1.SelBackColor = 16777216;
	G2antt1.SelForeColor = 65536;
	G2antt1.ShowFocusRect = false;
	G2antt1.DefaultItemHeight = 24;
	G2antt1.HeaderHeight = 24;
	G2antt1.DrawGridLines = 2;
	G2antt1.Columns.Add("C1");
	G2antt1.Columns.Add("C2");
	var var_Items = G2antt1.Items;
		var_Items.CellValue(var_Items.AddItem("Cell 1"),1) = "Cell 2";
		var_Items.CellValue(var_Items.AddItem("Cell 3"),1) = "Cell 4";
		var_Items.SelectPos = 1;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2194
How can I specify the cell's outline, border or lines around

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.AttachTemplate("handle AddColumn(Column){Column{Def(48)=4;Def(49)=4;}}");
	G2antt1.VisualAppearance.Add(1,"gBFLBCJwBAEHhEJAAEhABPEGACAADACAxRDgMQBQKAAzQFAYbBuGCGAAGIYBTgmFgAQhFcZQSpEEg7BKMYwjOJgFgmEQxDANIBQSKoaQiGQYYLhEZAEiONoaDJCM4wH" +
	"IMQxHCKTZRkGcfaRCGSfIzpGKpVgOTYiTbPcIyQKtBxDIydJTmeQQQhsFIJU7SdVUPDUJZlWbLAwWTAYazXCKRZBpeJqdo6Y5RUDKUqSdLUYyvEq7ZqnOIpw5vICpaCq" +
	"Op6HqKFpiXSAFL1fLmAwvPKrJjoeqpWpyCaRZQAGg4dbEdTNNCIbatQANKrCSpgZ7sMB6Di2L4TPS2awoWgRYyTFZMbBAeQ7LC1c45Fqrd4zS4dSxKCahcLxFiaNpYZY" +
	"njUap1jGPJlkuAgAkidB3nceZsCQEQJCgGhMGcQ4pkiSxEAAOYpiQIhvkYNA2gSCg5n+LIoGILowFyXQoAYAoAmASAWAaAZgggJgKF2T54DYDoDmECBGBKBJgGgTgWgW" +
	"YRoFYGIGmGOBqByB5hCgegggiYJYgoJIICIaIeByChixULILGGGAWDCCgjCiTgrg0YxojoC4OmOSJ2D6D5kAgJLFgABAEICA=");
	G2antt1.SelBackMode = 1;
	G2antt1.ShowFocusRect = false;
	G2antt1.DefaultItemHeight = 24;
	G2antt1.HeaderHeight = 24;
	G2antt1.DrawGridLines = 2;
	G2antt1.Columns.Add("C1");
	G2antt1.Columns.Add("C2");
	var var_Items = G2antt1.Items;
		var_Items.CellValue(var_Items.AddItem("Cell 1"),1) = "Cell 2";
		var h = var_Items.AddItem("Cell 2");
		var_Items.CellValue(h,1) = "Cell 3";
		var_Items.CellBackColor(h,1) = 16777216;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2193
Is it possible to highligth the match while a filter is applied

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="AddColumn(Column)" LANGUAGE="JScript">
	// Column.Def(17) = 1
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="FilterChange()" LANGUAGE="JScript">
	var format = G2antt1.FormatABC("`value replace '` + value + `' with '<bgcolor 000000><fgcolor FFFFFF>` + value  + `</fgcolor></bgcolor>'`",G2antt1.FilterBarPromptPattern,null,null);
	G2antt1.Columns.Item(0).FormatColumn = format;
	G2antt1.Columns.Item(1).FormatColumn = format;
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.DrawGridLines = 2;
	G2antt1.HeaderAppearance = 4;
	G2antt1.Columns.Add("Col 1");
	G2antt1.Columns.Add("Col 2");
	var var_Items = G2antt1.Items;
		var_Items.CellValue(var_Items.AddItem("219 Smith"),1) = "Ignacio 1234";
		var_Items.CellValue(var_Items.AddItem("1666 County Road 309A"),1) = "897 Manassa";
		var_Items.CellValue(var_Items.AddItem("38 Lone Pine"),1) = "Durango 11";
		var_Items.CellValue(var_Items.AddItem("612 Jachim Street"),1) = "Lamar 222";
	G2antt1.FilterBarPromptPattern = "1";
	G2antt1.FilterBarPromptVisible = 2067;
	G2antt1.FilterBarPromptType = 257;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2192
How can I display the total/sum/aggregate in the same column, when the user groups by a column

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="AddColumn(Column)" LANGUAGE="JScript">
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="AddGroupItem(Item)" LANGUAGE="JScript">
	var var_Items = G2antt1.Items;
		var_Items.ItemDivider(Item) = -1;
		var_Items.ItemBackColor(Item) = G2antt1.BackColorSortBar;
		var_Items.ItemHeight(Item) = G2antt1.HeaderHeight;
		var_Items.CellMerge(Item,0) = "1,2,3,4,5,7,8,9,10,11,12";
		var_Items.CellValue(Item,13) = "count(current,rec,1)";
		var_Items.CellValueFormat(Item,13) = 5;
		var_Items.CellValue(Item,0) = var_Items.CellCaption(Item,var_Items.GroupItem(Item));
		var_Items.FormatCell(Item,0) = "`<b>` + value + `</b> <font ;7><off 3><fgcolor=808080>(` + %13 +  `)`";
		var_Items.CellValue(Item,6) = "sum(current,all,dbl(%6))";
		var_Items.CellValueFormat(Item,6) = 5;
		var_Items.CellForeColor(Item,6) = 6710886;
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="Change(Item,ColIndex,NewValue)" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.LinesAtRoot = 5;
	G2antt1.Indent = 12;
	G2antt1.ColumnAutoResize = false;
	G2antt1.ScrollBySingleLine = true;
	G2antt1.BackColorSortBar = 15790320;
	G2antt1.AutoDrag = 16;
	var rs = new ActiveXObject("ADOR.Recordset");
		rs.Open("Orders","Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\Program Files\\Exontrol\\ExG2antt\\Sample\\Access\\misc.accdb",3,3,null);
	G2antt1.DataSource = rs;
	G2antt1.SingleSort = false;
	G2antt1.SortBarVisible = true;
	G2antt1.AllowGroupBy = true;
	G2antt1.HeaderHeight = 24;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Count").Visible = false;
		var var_Column = var_Columns.Item("Freight");
			var_Column.Def(4) = G2antt1.BackColorSortBar;
			var_Column.Def(7) = var_Column.Def(4);
			var_Column.Def(49) = 4;
			var_Column.Def(48) = 4;
			var_Column.HeaderBold = true;
			var_Column.AllowGroupBy = false;
			var_Column.FormatColumn = "value format ``";
			var_Column.Alignment = 2;
		var var_Column1 = var_Columns.Item(0);
			var_Column1.AllowGroupBy = false;
			var_Column1.Def(17) = 1;
		var_Columns.Item("ShipCountry").SortOrder = 1;
	G2antt1.ScrollBySingleLine = false;
	var var_Items = G2antt1.Items;
		var_Items.LockedItemCount(2) = 1;
		var hL = var_Items.LockedItem(2,0);
		var_Items.ItemHeight(hL) = 24;
		var_Items.ItemBold(hL) = true;
		var_Items.ItemBackColor(hL) = G2antt1.BackColorSortBar;
		var_Items.CellValue(hL,6) = "sum(all,rec,dbl(%6))";
		var_Items.CellValueFormat(hL,6) = 5;
		var_Items.CellHAlignment(hL,6) = 2;
		var_Items.FormatCell(hL,6) = "value format ``";
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2191
How do I add a total field locked at the bottom of the control

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="AddGroupItem(Item)" LANGUAGE="JScript">
	var var_Items = G2antt1.Items;
		var_Items.ItemDividerLine(Item) = 0;
		var_Items.FormatCell(Item,var_Items.GroupItem(Item)) = "value + ` Min: <b>` + %13 + `</b> Max: <b>` + %14 + `</b> Sum: <b>` + %15 + `</b>, of Freight column`";
		var_Items.CellValue(Item,"Min") = "min(current,all,dbl(%6))";
		var_Items.CellValueFormat(Item,"Min") = 4;
		var_Items.CellValue(Item,"Max") = "max(current,all,dbl(%6))";
		var_Items.CellValueFormat(Item,"Max") = 4;
		var_Items.CellValue(Item,"Sum") = "sum(current,all,dbl(%6))";
		var_Items.CellValueFormat(Item,"Sum") = 4;
		var_Items.ItemBackColor(Item) = 15790320;
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="Change(Item,ColIndex,NewValue)" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HasLines = 0;
	G2antt1.Description(26) = "Show/Hide";
	G2antt1.ColumnsFloatBarSortOrder = 1;
	G2antt1.ColumnsFloatBarVisible = 2;
	G2antt1.ColumnAutoResize = false;
	G2antt1.BackColorSortBar = 15790320;
	var rs = new ActiveXObject("ADOR.Recordset");
		rs.Open("Orders","Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\Program Files\\Exontrol\\ExG2antt\\Sample\\Access\\misc.accdb",3,3,null);
	G2antt1.DataSource = rs;
	G2antt1.SingleSort = false;
	G2antt1.SortBarVisible = true;
	G2antt1.AllowGroupBy = true;
	G2antt1.SortBarCaption = "Drag a <b>column</b> header here to group by that column.";
	var var_Columns = G2antt1.Columns;
		var var_Column = var_Columns.Add("Min");
			var_Column.Visible = false;
			var_Column.AllowDragging = false;
		var_Column = var_Columns.Add("Max");
			var_Column.Visible = false;
			var_Column.Visible = false;
			var_Column.AllowDragging = false;
		var var_Column1 = var_Columns.Add("Sum");
			var_Column1.Visible = false;
			var_Column1.Visible = false;
			var_Column1.AllowDragging = false;
	var var_Column2 = G2antt1.Columns.Item("Freight");
		var_Column2.FormatColumn = "currency(value)";
		var_Column2.Def(4) = 12895487;
		var_Column2.Def(7) = var_Column2.Def(4);
		var_Column2.HeaderBold = true;
		var_Column2.AllowGroupBy = false;
		var_Column2.Alignment = 2;
	G2antt1.ScrollBySingleLine = false;
	var var_Items = G2antt1.Items;
		var_Items.LockedItemCount(2) = 2;
		var hL = var_Items.LockedItem(2,0);
		var_Items.ItemDivider(hL) = 0;
		var_Items.ItemHeight(hL) = 3;
		var_Items.ItemDividerLineAlignment(hL) = 2;
		var_Items.ItemDividerLine(hL) = 2;
		hL = var_Items.LockedItem(2,1);
		var_Items.CellValue(hL,6) = "sum(all,rec,dbl(%6))";
		var_Items.CellValueFormat(hL,6) = 4;
		var_Items.ItemHeight(hL) = 24;
		var_Items.ItemBold(hL) = true;
	G2antt1.Columns.Item("EmployeeID").SortOrder = true;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2190
How can I add a total field, when I use grouping

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="AddGroupItem(Item)" LANGUAGE="JScript">
	var var_Items = G2antt1.Items;
		var_Items.ItemDividerLine(Item) = 0;
		var_Items.FormatCell(Item,var_Items.GroupItem(Item)) = "value + ` Min: <b>` + %13 + `</b> Max: <b>` + %14 + `</b> Sum: <b>` + %15 + `</b>, of Freight column`";
		var_Items.CellValue(Item,"Min") = "min(current,all,dbl(%6))";
		var_Items.CellValueFormat(Item,"Min") = 4;
		var_Items.CellValue(Item,"Max") = "max(current,all,dbl(%6))";
		var_Items.CellValueFormat(Item,"Max") = 4;
		var_Items.CellValue(Item,"Sum") = "sum(current,all,dbl(%6))";
		var_Items.CellValueFormat(Item,"Sum") = 4;
		var_Items.ItemBackColor(Item) = 15790320;
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="Change(Item,ColIndex,NewValue)" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HasLines = 0;
	G2antt1.ColumnAutoResize = false;
	G2antt1.BackColorSortBar = 15790320;
	var rs = new ActiveXObject("ADOR.Recordset");
		rs.Open("Orders","Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\Program Files\\Exontrol\\ExG2antt\\Sample\\Access\\misc.accdb",3,3,null);
	G2antt1.DataSource = rs;
	G2antt1.SingleSort = false;
	G2antt1.SortBarVisible = true;
	G2antt1.AllowGroupBy = true;
	G2antt1.Columns.Item(1).SortOrder = true;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Min").Visible = false;
		var_Columns.Add("Max").Visible = false;
		var_Columns.Add("Sum").Visible = false;
	var var_Column = G2antt1.Columns.Item("Freight");
		var_Column.Def(4) = 12895487;
		var_Column.Def(7) = var_Column.Def(4);
		var_Column.HeaderBold = true;
		var_Column.AllowGroupBy = false;
	G2antt1.ScrollBySingleLine = false;
	var var_Items = G2antt1.Items;
		var_Items.LockedItemCount(2) = 1;
		var hL = var_Items.LockedItem(2,0);
		var_Items.ItemDivider(hL) = 0;
		var_Items.ItemHeight(hL) = 24;
		var_Items.ItemDividerLineAlignment(hL) = 2;
		var_Items.ItemDividerLine(hL) = 2;
		var_Items.CellValue(hL,0) = "sum(all,rec,dbl(%6))";
		var_Items.CellValueFormat(hL,0) = 5;
		var_Items.CellHAlignment(hL,0) = 2;
		var_Items.FormatCell(hL,0) = "'Freight: <bgcolor=FFC4C4> '+(value format ``) + ` `";
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2189
How do I use the ColumnsFloatBarVisible on exColumnsFloatBarVisibleIncludeCheckColumns

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.ColumnAutoResize = false;
	G2antt1.HeaderAppearance = 4;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("City");
		var_Columns.Add("Start").Visible = false;
		var_Columns.Add("End").Visible = false;
	G2antt1.Description(26) = "Show/Hide";
	G2antt1.ColumnsFloatBarSortOrder = 1;
	G2antt1.ColumnsFloatBarVisible = 2;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2188
The BackColorAlternate displays each second row with a different background color. The question I have it is possible to apply a different background color for 3rd, 4th, row, and so on

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="LayoutChanged()" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="Sort()" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HasLines = 0;
	G2antt1.ColumnAutoResize = false;
	var rs = new ActiveXObject("ADOR.Recordset");
		rs.Open("Orders","Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\Program Files\\Exontrol\\ExG2antt\\Sample\\Access\\misc.accdb",3,3,null);
	G2antt1.DataSource = rs;
	var var_Column = G2antt1.Columns.Add("Position");
		var_Column.FormatColumn = "1 apos ''";
		var_Column.Visible = false;
	G2antt1.ConditionalFormats.Add("(%C13 mod 4) = 0",null).BackColor = 15790320;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2187
The BackColorAlternate looks fine for flat tables, but how about using it when displaying a hierarchy/tree, like grouping rows. The sample alternate colors for each group found

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="LayoutChanged()" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HasLines = 0;
	G2antt1.ColumnAutoResize = false;
	var rs = new ActiveXObject("ADOR.Recordset");
		rs.Open("Orders","Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\Program Files\\Exontrol\\ExG2antt\\Sample\\Access\\misc.accdb",3,3,null);
	G2antt1.DataSource = rs;
	G2antt1.SingleSort = false;
	G2antt1.SortBarVisible = true;
	G2antt1.AllowGroupBy = true;
	G2antt1.Columns.Item(1).SortOrder = true;
	var var_Column = G2antt1.Columns.Add("Position");
		var_Column.FormatColumn = "(0:= (1 rpos '')) left ( ( 1:= ( =:0 lfind `.` ) ) != -1 ? =:1 : len(=:0))";
		var_Column.Visible = false;
	G2antt1.ConditionalFormats.Add("(%C13 mod 2) != 0",null).BackColor = 15790320;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2186
I need to display sub-totals in the grouping items. Is there any solution on this

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="AddGroupItem(Item)" LANGUAGE="JScript">
	var var_Items = G2antt1.Items;
		var_Items.ItemDivider(Item) = -1;
		var_Items.EnableItem(Item) = false;
		var_Items.CellValueFormat(Item,G2antt1.TreeColumnIndex) = 1;
		var_Items.FormatCell(Item,G2antt1.TreeColumnIndex) = "%1";
		var_Items.CellValueFormat(Item,"Freight") = 5;
		var_Items.CellValue(Item,"Freight") = "sum(current,dir,%6)";
		var_Items.FormatCell(Item,"Freight") = "`<b>` + currency(value)";
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.SelBackMode = 1;
	G2antt1.BackColorSortBar = 15790320;
	G2antt1.ColumnAutoResize = false;
	var rs = new ActiveXObject("ADOR.Recordset");
		rs.Open("Orders","Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\Program Files\\Exontrol\\ExG2antt\\Sample\\Access\\misc.accdb",3,3,null);
	G2antt1.DataSource = rs;
	G2antt1.SortBarVisible = true;
	G2antt1.SortBarCaption = "Drag a <b>column</b> header here to group by that column.";
	G2antt1.AllowGroupBy = true;
	G2antt1.Columns.Item(1).SortOrder = 1;
	G2antt1.LinesAtRoot = 5;
	G2antt1.Columns.Item("ShipVia").DisplayFilterButton = true;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2185
I use a subtotal in exTop-Item, after grouping the item shows 0. What is the solution

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.ColumnAutoResize = false;
	var rs = new ActiveXObject("ADOR.Recordset");
		rs.Open("Orders","Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\Program Files\\Exontrol\\ExG2antt\\Sample\\Access\\misc.accdb",3,3,null);
	G2antt1.DataSource = rs;
	G2antt1.SingleSort = false;
	G2antt1.AllowGroupBy = true;
	G2antt1.SortBarVisible = true;
	G2antt1.BackColorSortBar = G2antt1.BackColor;
	G2antt1.Columns.Item(5).SortOrder = 1;
	G2antt1.Columns.Item(6).FormatColumn = "currency(value)";
	var var_Items = G2antt1.Items;
		var_Items.LockedItemCount(0) = 1;
		var h = var_Items.LockedItem(0,0);
		var_Items.ItemBackColor(h) = 15790320;
		var_Items.CellBackColor(h,6) = 12500670;
		var_Items.CellValue(h,6) = "sum(all,rec,%6)";
		var_Items.CellValueFormat(h,6) = 4;
	G2antt1.Refresh();
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2184
How can I add multiple values/columns on the same line/item/row

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="Change(Item,ColIndex,NewValue)" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.SortOnClick = 0;
	G2antt1.LinesAtRoot = 5;
	G2antt1.Indent = 13;
	G2antt1.HeaderVisible = false;
	G2antt1.LinesAtRoot = -1;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Items");
		var_Columns.Add("Quantity").Editor.EditType = 4;
		var_Columns.Add("Value").Editor.EditType = 4;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Items");
		var_Items.CellValue(h,2) = "sum(current,dir,dbl(%1)*dbl(%2))";
		var_Items.CellValueFormat(h,2) = 4;
		var_Items.FormatCell(h,2) = "`Total: `+ value";
		var_Items.CellHAlignment(h,2) = 2;
		var_Items.CellBold(h,2) = true;
		var_Items.CellEditorVisible(h,2) = false;
		var_Items.CellEditorVisible(h,1) = false;
		var h1 = var_Items.InsertItem(h,null,"Item 1");
		var_Items.CellValue(h1,1) = 10;
		var_Items.CellValue(h1,2) = 3;
		h1 = var_Items.InsertItem(h,null,"Item 2");
		var_Items.CellValue(h1,1) = 20;
		var_Items.CellValue(h1,2) = 4;
		var_Items.ExpandItem(h) = true;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2183
Is it possible, to add more aggregate functions to grouping header

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="AddGroupItem(Item)" LANGUAGE="JScript">
	var var_Items = G2antt1.Items;
		var_Items.FormatCell(Item,var_Items.GroupItem(Item)) = "value + ` Min: <b>` + %13 + `</b> Max: <b>` + %14 + `</b> Sum: <b>` + %15 + `</b>, of Freight column`";
		var_Items.CellValue(Item,"Min") = "min(current,all,dbl(%6))";
		var_Items.CellValueFormat(Item,"Min") = 4;
		var_Items.CellValue(Item,"Max") = "max(current,all,dbl(%6))";
		var_Items.CellValueFormat(Item,"Max") = 4;
		var_Items.CellValue(Item,"Sum") = "sum(current,all,dbl(%6))";
		var_Items.CellValueFormat(Item,"Sum") = 4;
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="Change(Item,ColIndex,NewValue)" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HasLines = 0;
	G2antt1.ColumnAutoResize = false;
	var rs = new ActiveXObject("ADOR.Recordset");
		rs.Open("Orders","Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\\Program Files\\Exontrol\\ExG2antt\\Sample\\Access\\misc.accdb",3,3,null);
	G2antt1.DataSource = rs;
	G2antt1.SingleSort = false;
	G2antt1.SortBarVisible = true;
	G2antt1.AllowGroupBy = true;
	G2antt1.Columns.Item(1).SortOrder = true;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Min").Visible = false;
		var_Columns.Add("Max").Visible = false;
		var_Columns.Add("Sum").Visible = false;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2182
Is it possible to display more aggregate functions to a single cell (method 2)

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="Change(Item,ColIndex,NewValue)" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.SortOnClick = 0;
	G2antt1.LinesAtRoot = 5;
	G2antt1.Indent = 13;
	G2antt1.HeaderVisible = false;
	G2antt1.LinesAtRoot = -1;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Items");
		var_Columns.Add("Quantity").Editor.EditType = 4;
		var_Columns.Add("Sum").Visible = false;
		var_Columns.Add("Min").Visible = false;
		var_Columns.Add("Max").Visible = false;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Items");
		var_Items.CellMerge(h,0) = 1;
		var_Items.FormatCell(h,0) = "`Items, <b>sum(` + %2 + `), min(` + %3 + `), max(` + %4 + `)</b>`";
		var_Items.CellValueFormat(h,0) = 1;
		var_Items.CellValue(h,2) = "sum(current,dir,dbl(%1))";
		var_Items.CellValueFormat(h,2) = 4;
		var_Items.CellValue(h,3) = "min(current,dir,dbl(%1))";
		var_Items.CellValueFormat(h,3) = 4;
		var_Items.CellValue(h,4) = "max(current,dir,dbl(%1))";
		var_Items.CellValueFormat(h,4) = 4;
		var_Items.CellValue(var_Items.InsertItem(h,null,"Item 1"),1) = 10;
		var_Items.CellValue(var_Items.InsertItem(h,null,"Item 2"),1) = 20;
		var_Items.CellValue(var_Items.InsertItem(h,null,"Item 3"),1) = 30;
		var_Items.ExpandItem(h) = true;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2181
How can I use the current in the aggregate/total field

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="Change(Item,ColIndex,NewValue)" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.SortOnClick = 0;
	G2antt1.LinesAtRoot = 5;
	G2antt1.Indent = 13;
	G2antt1.HeaderVisible = false;
	G2antt1.LinesAtRoot = -1;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Items");
		var_Columns.Add("Quantity").Editor.EditType = 4;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Items");
		var_Items.CellValue(h,1) = "sum(current,dir,dbl(%1))";
		var_Items.CellValueFormat(h,1) = 4;
		var_Items.FormatCell(h,1) = "`Total: `+ value";
		var_Items.CellValue(var_Items.InsertItem(h,null,"Item 1"),1) = 10;
		var_Items.CellValue(var_Items.InsertItem(h,null,"Item 2"),1) = 20;
		var_Items.CellValue(var_Items.InsertItem(h,null,"Item 3"),1) = 30;
		var_Items.ExpandItem(h) = true;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2180
The CellValue/CellCaption property gets the result of a computed/total field with text formatting. Is it possible to get that value without text formatting

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("A").Editor.EditType = 4;
	G2antt1.Columns.Add("B").Editor.EditType = 4;
	G2antt1.Columns.Add("A+B");
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem(10);
		var_Items.CellValue(h,1) = 20;
		var_Items.CellValueFormat(h,2) = 2;
		var_Items.CellValue(h,2) = "currency(dbl(%0)+dbl(%1))";
		alert( "CellCaption returns " );
		alert( var_Items.CellCaption(h,2) );
		alert( "CellValue returns " );
		alert( var_Items.CellValue(h,2) );
		alert( "ComputeValue returns " );
		alert( var_Items.ComputeValue("dbl(%0)+dbl(%1)",h,0,var_Items.CellValueFormat(h,2)) );
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2179
Can I get the result of a specified formula as your control does using the ComputedField property
<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("A");
	G2antt1.Columns.Add("B");
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem(10);
		var_Items.CellValue(h,1) = 20;
		alert( "A+B is " );
		alert( var_Items.ComputeValue("dbl(%0)+dbl(%1)",h,0,2) );
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2178
Is it possible to get the text without HTML formatting
<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("");
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("<b>bold</b>");
		alert( var_Items.ComputeValue(var_Items.CellValue(h,0),h,0,1) );
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2177
Transparent/Border SummaryBar

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="AddGroupItem(Item)" LANGUAGE="JScript">
	var var_Items = G2antt1.Items;
		var_Items.ItemDividerLine(Item) = 0;
		var_Items.AddBar(Item,"Summary","12/2/2017","12/2/2017",null,null);
		var_Items.DefineSummaryBars(Item,"",-3,"");
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="AddItem(Item)" LANGUAGE="JScript">
	G2antt1.Items.AddBar(Item,"Task","12/4/2017","12/10/2017",null,null);
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.VisualAppearance.Add(1,"gBFLBCJwBAEHhEJAAEhABHEGACAADACAxRDgMQBQKAAzQFAYbBuGCGAAGIYBTgmFgAQhFcZQSKUOQTDKMIziaQJiYLBIaRgEUTRXASCQxDBKQBSeKkRRtDaOYDnGQYD" +
	"iCIouQLEIxDKItBSJCKURJkAZZHjeToSR5PMb0dKdAw5I6raShEaaIiqJIXP7Fc7QSA0EgTBIFajgOpQAb+bptW7FVDULTMQS5FCZKasOA7FgOZ4DWjUVpwTZ1Q4LC65" +
	"bjuaraawKbYbXrFYJQSA8EwjNjDcLuKqcKpvDJsSJIFKxOB2KYtBLMLbzLR5apjLZ0QLSOKRDoMEgRDYGdKjLScGrGao8ABtcBlAZJRjoOo5DJgeCQapUQhNczGQzQSI" +
	"iBOJZAFSQwRHcJhGh2BZvngMIeA8H4TksA5ylgZBeg8X4GmGX4nniPazneQ5VnKdp9H8P4vD+X57nMRofmgBZ4FgIAoBWdoBGAGAeAgfxfjgNZ1DqWxEA0ASAgA==");
	var var_Chart = G2antt1.Chart;
		var_Chart.LevelCount = 2;
		var_Chart.FirstVisibleDate = "12/2/2017";
		var_Chart.PaneWidth(false) = 256;
		var var_Bar = var_Chart.Bars.Item("Summary");
			var_Bar.Color = 16777216;
			var_Bar.Def(3) = "<%=%513%>";
			var_Bar.Def(4) = 18;
			var_Bar.Def(58) = 8;
		var var_Bar1 = var_Chart.Bars.Item("Task");
			var_Bar1.Pattern = 32;
			var_Bar1.Color = 0;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("C1");
		var_Columns.Add("C2");
		var var_Column = var_Columns.Add("Pos");
			var_Column.FormatColumn = "1 pos ``";
			var_Column.AllowGroupBy = false;
			var_Column.Position = 0;
			var_Column.Width = 48;
			var_Column.AllowSizing = false;
	G2antt1.SortBarVisible = true;
	G2antt1.AllowGroupBy = true;
	G2antt1.BackColorSortBar = G2antt1.BackColor;
	G2antt1.HeaderAppearance = 4;
	var var_Items = G2antt1.Items;
		var_Items.CellValue(var_Items.AddItem("Item A"),1) = "SubItem A.1";
		var_Items.CellValue(var_Items.AddItem("Item A"),1) = "SubItem A.2";
		var_Items.CellValue(var_Items.AddItem("Item A"),1) = "SubItem A.3";
		var_Items.CellValue(var_Items.AddItem("Item A"),1) = "SubItem A.4";
		var_Items.CellValue(var_Items.AddItem("Item B"),1) = "SubItem B.1";
		var_Items.CellValue(var_Items.AddItem("Item B"),1) = "SubItem B.2";
	G2antt1.Columns.Item(0).SortOrder = 1;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2176
The bar's caption is very difficult to read if any pattern than exPatternSolid is used. Is there any way of displaying the bar's caption (except for displaying the caption outside the bar)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Font.Size = 12;
	G2antt1.DefaultItemHeight = 24;
	G2antt1.Columns.Add("Task");
	var var_Chart = G2antt1.Chart;
		var_Chart.LevelCount = 2;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var var_Bar = var_Chart.Bars.Item("Task");
			var_Bar.Height = 21;
			var_Bar.Pattern = 7;
		var_Chart.PaneWidth(false) = 128;
		var_Chart.UnitWidth = 24;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("");
		var_Items.AddBar(h,"Task","1/2/2001","1/6/2001","",null);
		var_Items.ItemBar(h,"",3) = "to do";
		h = var_Items.AddItem("bgcolor");
		var_Items.AddBar(h,"Task","1/2/2001","1/6/2001","",null);
		var_Items.ItemBar(h,"",3) = "<bgcolor=FFFFFF> to do </bgcolor>";
		h = var_Items.AddItem("fgcolor");
		var_Items.AddBar(h,"Task","1/2/2001","1/6/2001","",null);
		var_Items.ItemBar(h,"",3) = "<fgcolor=FFFFFF> to do </fgcolor>";
		h = var_Items.AddItem("sha");
		var_Items.AddBar(h,"Task","1/2/2001","1/6/2001","",null);
		var_Items.ItemBar(h,"",3) = "<sha FFFFFF;2;2> to do </sha>";
		h = var_Items.AddItem("out");
		var_Items.AddBar(h,"Task","1/2/2001","1/6/2001","",null);
		var_Items.ItemBar(h,"",3) = "<out 000000><fgcolor=FFFFFF>to do</fgcolor></out></font>";
		h = var_Items.AddItem("gra");
		var_Items.AddBar(h,"Task","1/2/2001","1/6/2001","",null);
		var_Items.ItemBar(h,"",3) = "<fgcolor FFFFFF><gra 000000;1;1>to do</fgcolor>";
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2175
How can I change the position of the bar's tooltip

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="ToolTip(Item,ColIndex,Visible,X,Y,CX,CY)" LANGUAGE="JScript">
	alert( "ToolTip" );
	alert( Item );
	alert( ColIndex );
	alert( Visible );
	alert( X );
	alert( Y );
	alert( CX );
	alert( CY );
	X = G2antt1.FormatABC("value + 8",X,null,null);
	Y = G2antt1.FormatABC("value - 8",Y,null,null);
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Task");
	var var_Chart = G2antt1.Chart;
		var_Chart.PaneWidth(false) = 64;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.Bars.Item("Task").Def(6) = "<b><%=%9 + '/' + %C0%></b><br><upline><dotline>Start: <%=%1%><br>End: <%=%2%><br>Duration: <%=(%2-%1)%><br>Working: <%=%258%>";
		var_Chart.LevelCount = 2;
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem("Tasks A"),"Task","1/2/2001","1/4/2001",null,null);
		var_Items.AddBar(var_Items.AddItem("Tasks B"),"Task","1/3/2001","1/8/2001",null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2174
How can I replace the cell's context menu ( while edit mode is running )

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="RClick()" LANGUAGE="JScript">
	alert( "Edit Mode: " );
	alert( G2antt1.Editing );
	var var_ExContextMenu = new ActiveXObject("Exontrol.ContextMenu");
		var_ExContextMenu.Items.ToString = "Check[chk],[sep],Item 1,Item 2,Item 3,Popup(A,B,C)";
		alert( var_ExContextMenu.Select(null,null,null) );
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HeaderAppearance = 1;
	var var_Editor = G2antt1.Columns.Add("Column").Editor;
		var_Editor.EditType = 1;
		var_Editor.Option(202) = false;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("Item 1");
		var_Items.AddItem("Item 2");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2173
Is it possible to highlight the column's header once a filter is applied (sample 2)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Appearance = G2antt1.VisualAppearance;
		var_Appearance.Add(1,"gBFLBCJwBAEHhEJAAEhABO8GACAADACAxRDgMQBQKAAzQFAYbBuGCGAAGIYBTgmFgAQhFcZQSKUOQTDKNYykCIRSDUJYkSZEIyjBI8ExXFqNACkGKwQgmNYDSBMcbwS" +
	"AsXRYFocJ5gOT6AjKBA2UclEZpajiTY3ABUEgUS5oOBIACqariaQJAAiCRQGiYZyHKaRSwPBKFYDIIjbJheTIDChNVxUcDENQjJqLBIDRzbarye59YBfeBXdgmA4LQbD" +
	"MRwNgMMQTDqKYbkOQZHbeGKAWTMEZzJj8cxTEqIaBhGTLfojSZMS7UGK1LLtMyHI6kP7sOiLfi2W4/W7XV72F79TzXIa2ZBuO57bhnAZ/VzGNj4PRNezfRqicjsGxcZw" +
	"Xg+TpQj0ew6gSOw7wSbozjsfYXi8PwMnSc52leHotl+MxjmoXh2nybxOH+SQtnYXx+D2P4vGMB56hQf5PCgBYeDwYBCEo1xggebgKH6IIDBYBgkiAQ5FgYPAhEIRgWGq" +
	"DBoC4GoCiGCBYhGBQPAWdIQp0eIUiWCZigiJgqgqYpIioJQhmIMhBH0NxjEMag2g2Y4ImYOoOmOSJeDQNxXlOLR3ECUAQICA=");
		var_Appearance.Add(2,"gBFLBCJwBAEHhEJAAEhABgsHQAAYAQGKIcBiAKBQAGaAoDDYNwwQwAAxDAKcEwsACEIrjKCRShyCYZRrGUgRCKQahLEiTIhGUYJHgmK4tRoAUgxWCEExrAaQJjjeCQF" +
	"i6LAtDhPMByfQEZQIGyjkgjNLUcSbG4AKgkCiXfpUAJVP7FcgSABEEigNIxToOU4jFgeCYLQKQRK2RC9GQGFCbLhpYKIahGTYWVheN5XXblez9P7ABQwKCcAwXBp7YIK" +
	"AT4XBIdYdQ7IL4xGA0AJPFoJC7mOQ5XiYAIBAZ/RL0LCcbxHHafVboQj6JouD5PUDVNY1XBdPynI6CbLhWy6Dq4UZzPwzeBifSHfDjRoJcCZe71KY3GwSEboNA6Kp+QB" +
	"HAmZoZjSPYIEiF47lOLJVnuYofBwJJHmaQoYj0MIRHeM4/m6cJ8B+fpBHQJ5SGKPYYH8OYMk+P5Bn4fxaAYZAvEIX4RgUWBGgCCAmAqApgkgNgOgMEYlGASoEkQeBWBa" +
	"BZhggZgagaYRoEwShWA6NZZAMQBAICA==");
	G2antt1.Background(0) = 16777216;
	G2antt1.Background(41) = 33554432;
	G2antt1.Background(32) = -1;
	G2antt1.HeaderHeight = 28;
	G2antt1.BackColorHeader = 16777215;
	G2antt1.DrawGridLines = -2;
	G2antt1.HeaderVisible = 1;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("C1").DisplayFilterButton = true;
		var var_Column = var_Columns.Add("C2");
			var_Column.DisplayFilterButton = true;
			var_Column.Filter = "Item 2";
			var_Column.FilterType = 240;
		var_Columns.Add("C3").DisplayFilterButton = true;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Item 1");
		var_Items.CellValue(h,1) = "Item 2";
		var_Items.CellValue(h,2) = "Item 3";
		h = var_Items.AddItem("Item 4");
		var_Items.CellValue(h,1) = "Item 5";
		var_Items.CellValue(h,2) = "Item 6";
	G2antt1.ApplyFilter();
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2172
How can I make the expand/collapse glyphs DPI aware

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	var size = 2;
	G2antt1.BeginUpdate();
	var var_Appearance = G2antt1.VisualAppearance;
		var_Appearance.Add(3,"gBFLBCJwBAEHhEJAAEhEGAUHQAAYAQGKIcBiAKBQAGaAoDDYOA4QwAAxDAKcEwsACEIrjKCRShyCYZRhGcTSBCIZBqEqSZLiEZRQiiCYsS5GQBRfIUEghGyNZjgNzQc" +
	"CQAI8T5IUgARBJIDSMY6DpOIxYHgmC4DEITNLxOK0EhRHCBZrgOCAYhqEY1Ro+dhPFYjVTMdK0LRtKy7Mq2aJmOpZDxWE7dZKpO5fbxXS67cr2fp/YBed4rfa7KTlOBK" +
	"cRQRBEFQPDqPZBkORZHh2FoLRJKbgtHJmHYNQWhVyYBbNCyTI6lahpeuHBx1QaWWxjbCMEr6bpoWLbFi3Ha1UzrPa8b5vSw7Gr+HzYQTHGPXGqaYJdZrnea6B7+U5XUJ" +
	"rnSOZciYHwhAeR5HDK+JVGqKRRmScx5HyfRei+H5bmmcp4Fi8o/CGGJKGQKZUGoFQigUPIiCeSZXnyHB6l0SAJn8JxfkIeZ5CgXxjCCAhyB8QgIlAM4MlKAIcCaIBIGY" +
	"GoGGEYhqBMMxgnICgRDUDQjESGwmAkWBuCqBoiHIVgkDQYgYESWg2E0YhohcJQigITg3CQSRyEyEYGGOWJwhQJD4FiFIMk0aJFGsIBkkOBJeDc+AchYJwJgIWhSgYZQp" +
	"FIVoVGOGQ4l2EwIBWMhgDmDhThCEwkAiaJchKDhjhgZhsCUY4iFCEoZkiaYQmSGAWhWQhgDuDpTjCDQiEgchAg0IpJBoDoFiEKBqCaCAimgIguH8IZnkPUhcBcJg+hGJ" +
	"ZnloYJsiaKZKGa24YnWSR0CkKhCA2CxlCqColhAYpqEKER0DqVZ0A0ASAgA==");
		var_Appearance.Add(4,"gBFLBCJwBAEHhEJAAEhABAQCg6AADACAxRDgMQBQKAAzQFAYbBwHCGAAGIYBTgmFgAQhFcZQSKUOQTDKNYykCIRSDUJYkSZEIyjBI8ExXFqNACjeQYJBCNYbTJAbqhY" +
	"IgAR3HqQZABCCSQKkYx0HScRiwPBMFwGIQmaaicZoJCiN4DTZAcIBRDUIxpDR9bBeKw3KqVaZnWhaNpWXZlTzKdSxXisF67RZSdi/XgvF5XXblez9P69LwXe5mUrGbyV" +
	"YghCCIKgeG4dR7IMhyLDcKQXCCVW7aGSsOwbAqAXpdGAXTQdDyLJKnaZqOi6BjjA4rNbHGIYJb1XTRMa1LJuG5LJrOeZ3Xre4BLfh1VoFRpjWIYNY1QS7TLOczzfRdDx" +
	"TiGVpkjCeJoD4Ng1hSRxiisVRKg8D4PkWZJznmPQ+F8Xx5guWpjHGWYMiYQodEaIRSCgU5KCSeh3naHB/iAAh9n8fwfgIeZ1CgXwjCCAhxl8AgIlAM4MlKAIcCaD54FY" +
	"FoFmGCBmBaBIJigPJNgKSAoDSVC+BIbIYCUYYoiYKoJgkWIMlGCAglMaJZDWCYiFyFIJkkOJYhEJc7G4PYPCOaJshQJBjgiVIUgyDRokEaggGSQ4El4N1CBiFgnAmAha" +
	"FKFZlFkShUhWJRYmITg3GSQgFGuGBOGOFJkCSSQCDoNgkiOCY0hUJJmmmQhvhqZtYmUOQmBWIRvhgTpjjSbAjEiEgchBZgyEaBIhigWgegqIhIjoDILiACB5nTL5WnWR" +
	"YOiSKYJnqGQ7CmOh2hqJ5OkYORxFyShKhSAxihkOomioY5YiqFIkFyTo1HkAxAEAgIA==");
		var_Appearance.Add(1,G2antt1.FormatABC("`CP:3 -` + int(value*dpi) + ` -` + int(value*dpi) + ` ` +  int(value*dpi) + ` ` + int(value*dpi)",size,null,null));
		var_Appearance.Add(2,G2antt1.FormatABC("`CP:4 -` + int(value*dpi) + ` -` + int(value*dpi) + ` ` +  int(value*dpi) + ` ` + int(value*dpi)",size,null,null));
	G2antt1.LinesAtRoot = 1;
	G2antt1.HasButtons = 4;
	G2antt1.HasButtonsCustom(0) = 16777216;
	G2antt1.HasButtonsCustom(1) = 33554432;
	G2antt1.Columns.Add("Column");
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Root 1");
		var_Items.InsertItem(h,null,"Child 1");
		var_Items.InsertItem(h,null,"Child 2");
		var_Items.ExpandItem(h) = true;
		h = var_Items.AddItem("Root 2");
		var_Items.InsertItem(h,null,"Child");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2171
Is it possible to highlight the column's header once a filter is applied (sample 1)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Appearance = G2antt1.VisualAppearance;
		var_Appearance.Add(2,"gBFLBCJwBAEHhEJAAEhABX8GACAADACAxSDEMQBQKAAzQFAYbhgHCGAAGQaBUgmFgAQhFcZQSKUOQTDKNYykCIRSDUJYkSZEIyjBI8ExXFqNACkGKwYgmNYiTLAcgAN" +
	"J0WBaGIZJ4gOT5fDKMoEDRRYADFCscwxJybQAqGQKKb+VgAVY/cTyBIAEQSKA0TDOQ5TSKWB4JPZQRBEbZMNBtBIUJquKaqShdQJCU5FdY3Xblez9P7AMBwLFEC4NQ8Y" +
	"NYuPhjR4dRTIMhvVAsUArFh8Zg9GZZFjmDIDT4ydBLTQwcyVIKnP5qOa6XbmPoCQDYKxZHYxPzVDa3axuL76dqCAT7XrXNy1TbNRrzQKfcJqfCbdw2YaDZLOOT3fjuI4" +
	"hhKaRzFAHJ+jYQ4xHuY4gHuGIXGeExqC8Tp6C+PoEm+G5ImycRgh0XwvDGa5rgOeoejyXwnFeQp2mkf5ClgBB9gCWIYAwfYAEKV58mkdwOggNArgOXY2EWLoDkKOA0mg" +
	"bhOGgZApgaSBIHWSYHSmbApgYThmESZYJkIeIkgeCpfliLIHgpMIcmUYYYmODAlg2SI4mWfRfGOEguDcCRjFYAJihCQhJBSDoRmONgKEcI4kFCEJhhOVYTmYnAlEAQhW" +
	"BMJYJGYWoWmWSR2F6F5lnkWAQhUAgpEieRWEuSYkjWGpmkmNhuhuZwJkYcocmaaYkjyEhngnUA6lEFAlAEgI=");
		var_Appearance.Add(1,"CP:2 -8 -4 2 4");
	G2antt1.Background(0) = 33488638;
	G2antt1.Background(41) = 16843009;
	G2antt1.Background(32) = -1;
	G2antt1.HeaderHeight = 28;
	G2antt1.BackColorHeader = 16777215;
	G2antt1.DrawGridLines = -2;
	G2antt1.HeaderVisible = 1;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("C1").DisplayFilterButton = true;
		var var_Column = var_Columns.Add("C2");
			var_Column.DisplayFilterButton = true;
			var_Column.Filter = "Item 2";
			var_Column.FilterType = 240;
		var_Columns.Add("C3").DisplayFilterButton = true;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Item 1");
		var_Items.CellValue(h,1) = "Item 2";
		var_Items.CellValue(h,2) = "Item 3";
		h = var_Items.AddItem("Item 4");
		var_Items.CellValue(h,1) = "Item 5";
		var_Items.CellValue(h,2) = "Item 6";
	G2antt1.ApplyFilter();
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2170
How do I update itemcount and matchitemcount of the FilterBarCaption after I added the item using the AddItem method
<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="Click()" LANGUAGE="JScript">
	G2antt1.Items.AddItem("new");
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Chart.PaneWidth(true) = 0;
	var var_Column = G2antt1.Columns.Add("Item");
		var_Column.DisplayFilterButton = true;
		var_Column.FilterList = 9504;
	var var_Column1 = G2antt1.Columns.Add("Pos");
		var_Column1.AllowSizing = false;
		var_Column1.AllowSort = false;
		var_Column1.Width = 32;
		var_Column1.FormatColumn = "1 apos ``";
		var_Column1.Position = 0;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("Item A");
		var_Items.AddItem("Item B");
		var_Items.AddItem("Item C");
	G2antt1.FilterBarCaption = "`<r>` + value + `</b><fgcolor=808080>` + ( matchitemcount < 0 ? ( ( len(value) ? `<br>` : `` ) + `<r>` + abs(matchitemcount + 1" +
	") + ` result(s)` ) : (`<fgcolor=808080>`+ itemcount + ` item(s)`) )";
	G2antt1.FilterBarPromptVisible = 3591;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2169
The Edit method does not work while ReadOnly property is exLocked and the first column is hidden. Is there any fix

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="DblClick(Shift,X,Y)" LANGUAGE="JScript">
	var var_ItemFromPoint = G2antt1.ItemFromPoint(-1,-1,c,hit);
	G2antt1.FocusColumnIndex = c;
	G2antt1.Edit(null);
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Chart.PaneWidth(true) = 0;
	G2antt1.HeaderAppearance = 4;
	G2antt1.AutoEdit = false;
	G2antt1.ReadOnly = 1;
	G2antt1.AutoSearch = true;
	G2antt1.Columns.Add("").Visible = false;
	var var_Column = G2antt1.Columns.Add("Contains");
		var_Column.AutoSearch = 1;
		var_Column.Editor.EditType = 1;
	var var_Items = G2antt1.Items;
		var_Items.CellValue(var_Items.AddItem(null),1) = "Tom Hanks";
		var_Items.CellValue(var_Items.AddItem(null),1) = "Leonardo DiCaprio";
		var_Items.CellValue(var_Items.AddItem(null),1) = "Will Smith";
		var_Items.CellValue(var_Items.AddItem(null),1) = "Tom Cruise";
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2168
How can I highlight the cell's button with a different appearance, when cursor hovers it

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.VisualAppearance.Add(1,"c:\\exontrol\\images\\normal.ebn");
	G2antt1.DefaultItemHeight = 22;
	G2antt1.TreeColumnIndex = -1;
	G2antt1.SelForeColor = 0;
	G2antt1.SelBackColor = G2antt1.BackColor;
	G2antt1.Background(157) = 16777216;
	var var_Column = G2antt1.Columns.Add("Buttons");
		var_Column.Def(2) = true;
		var_Column.Def(17) = 1;
		var_Column.Alignment = 1;
		var_Column.HeaderAlignment = 1;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("Button <b>1</b>");
		var_Items.AddItem("Button <b>2</b>");
		var_Items.AddItem("Button <b>3</b>");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2167
How to group one or more operations into a block when the user do undo or redo

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Tasks");
	var var_Chart = G2antt1.Chart;
		var_Chart.AllowUndoRedo = true;
		var_Chart.FirstVisibleDate = "6/20/2005";
		var_Chart.AllowLinkBars = true;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(0) = 64;
		var_Chart.Bars.Item("Task").Height = 16;
	var var_Items = G2antt1.Items;
		var_Items.StartBlockUndoRedo();
		var_Items.AddBar(var_Items.AddItem("Task 1"),"Task","6/23/2005","6/27/2005","",null);
		var_Items.AddBar(var_Items.AddItem("Task 2"),"Task","6/28/2005","7/2/2005","",null);
		var_Items.AddLink("L1",var_Items.ItemByIndex(0),"",var_Items.ItemByIndex(1),"");
		var_Items.EndBlockUndoRedo();
		var h = var_Items.ItemByIndex(1);
	var var_Note = G2antt1.Chart.Notes.Add("NoteD",h,"6/26/2005","CTRL+Z (undo), CTRL+Y (redo)");
		var_Note.PartShadow(1) = false;
		var_Note.PartToolTip(1) = "Press CTRL+Z to undo <br> and then press CTRL+Y to redo";
		var_Note.PartTransparency(1) = 25;
		var_Note.PartVOffset(1) = -2;
		var_Note.PartBackColor(1) = 65535;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2166
I am using the Link property to customize the link, but when I press redo it (CTRL+Y) to redo it, not all properties are restored. What can be done

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Tasks");
	var var_Chart = G2antt1.Chart;
		var_Chart.AllowUndoRedo = true;
		var_Chart.FirstVisibleDate = "6/20/2005";
		var_Chart.AllowLinkBars = true;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(0) = 64;
		var_Chart.Bars.Item("Task").Height = 16;
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem("Task 1"),"Task","6/23/2005","7/1/2005","",null);
		var_Items.AddBar(var_Items.AddItem("Task 2"),"Task","6/27/2005","7/4/2005","",null);
		var_Items.StartBlockUndoRedo();
		var_Items.AddLink("L1",var_Items.ItemByIndex(0),"",var_Items.ItemByIndex(1),"");
		var u = var_Items.StartUpdateLink("L1");
		var_Items.Link("L1",10) = 2;
		var_Items.Link("L1",12) = "<fgcolor FF0000>CTRL+Z (undo), CTRL+Y (redo)";
		var_Items.Link("L1",13) = "Press CTRL+Z to undo <br> and then press CTRL+Y to redo";
		var_Items.Link("L1",6) = 0;
		var_Items.Link("L1",8) = 255;
		var_Items.EndUpdateLink(u);
		var_Items.EndBlockUndoRedo();
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2165
I am using the ItemBar property to customize the task, but when I press redo it (CTRL+Y) to redo it, not all properties are restored. What can be done

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Tasks");
	var var_Chart = G2antt1.Chart;
		var_Chart.AllowUndoRedo = true;
		var_Chart.FirstVisibleDate = "6/20/2005";
		var_Chart.AllowLinkBars = true;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(0) = 64;
		var_Chart.Bars.Item("Task").Height = 16;
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem("Task 1"),"Task","6/21/2005","6/30/2005","",null);
		var h = var_Items.AddItem("Task 2");
		var_Items.StartBlockUndoRedo();
		var_Items.AddBar(h,"Task","6/27/2005","7/4/2005","","CTRL+Z (undo), CTRL+Y (redo)");
		var u = var_Items.StartUpdateBar(h,"");
		var_Items.ItemBar(h,"",33) = 255;
		var_Items.ItemBar(h,"",6) = "Press CTRL+Z to undo <br> and then press CTRL+Y to redo";
		var_Items.EndUpdateBar(u);
		var_Items.EndBlockUndoRedo();
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2164
The incremental search feature is no working for columns with editor assigned. What can be done

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="DblClick(Shift,X,Y)" LANGUAGE="JScript">
	G2antt1.Edit(null);
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Chart.PaneWidth(true) = 0;
	G2antt1.HeaderAppearance = 4;
	G2antt1.AutoEdit = false;
	G2antt1.AutoSearch = true;
	var var_Column = G2antt1.Columns.Add("Contains");
		var_Column.AutoSearch = 1;
		var_Column.Editor.EditType = 1;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("Tom Hanks");
		var_Items.AddItem("Leonardo DiCaprio");
		var_Items.AddItem("Will Smith");
		var_Items.AddItem("Tom Cruise");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2163
Each item is representated by a key as string. Is it possible to have a drop down editor to display more information when using the item's key

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Chart.PaneWidth(true) = 0;
	G2antt1.HeaderAppearance = 4;
	var var_Editor = G2antt1.Columns.Add("Multiple-Columns Tree DropDownListType").Editor;
		var_Editor.EditType = 3;
		var_Editor.AddItem(0,"KR|Korea, Republic of",null);
		var_Editor.AddItem(1,"MO|Macao",null);
		var_Editor.AddItem(2,"SA|Saudi Arabia",null);
		var_Editor.AddItem(3,"EG|Egypt",null);
		var_Editor.AddItem(4,"GB|United Kingdom",null);
		var_Editor.AddItem(5,"GT|Guatemala",null);
		var_Editor.AddItem(6,"SR|Suriname",null);
		var_Editor.AddItem(7,"BM|Bermuda",null);
	var var_Items = G2antt1.Items;
		var_Items.AddItem("EG");
		var_Items.AddItem("GB");
		var_Items.AddItem("BM");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2162
My table includes codes/keys for items, can I display a drop down editor to include more information

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Chart.PaneWidth(true) = 0;
	G2antt1.HeaderAppearance = 4;
	var var_Editor = G2antt1.Columns.Add("Multiple-Columns DropDownListType").Editor;
		var_Editor.EditType = 3;
		var_Editor.DropDownAutoWidth = 0;
		var_Editor.Option(57) = "City¦Coordinates¦State";
		var_Editor.AddItem(0,"JV3|Jollyville¦3026N 09746W¦Texas",null);
		var_Editor.AddItem(1,"TMO|Altamont¦4021N 11017W¦Utah",null);
		var_Editor.AddItem(2,"IIM|Williamston¦4241N 08417W¦Michigan",null);
		var_Editor.AddItem(3,"IWN|Merrittstown¦3958N 07952W¦Pennsylvania",null);
		var_Editor.AddItem(4,"HOU|Houston¦2945N 09521W¦Texas",null);
		var_Editor.AddItem(5,"GSF|Gales Ferry¦4125N 07205W¦Connecticut",null);
	var var_Items = G2antt1.Items;
		var_Items.AddItem("HOU");
		var_Items.AddItem("IIM");
		var_Items.AddItem("TMO");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2161
How can I display and select from a multiple-columns tree editor

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Chart.PaneWidth(true) = 0;
	G2antt1.Images("gBJJgBAIDAAGAAEAAQhYAf8Pf4hh0QihCJo2AEZjQAjEZFEaIEaEEaAIAkcbk0olUrlktl0vmExmUzmk1m03nE5nU7nk9n0/oFBoVDolFo1HpFJpVLplNp1PqFRqVTq" +
	"lVq1XrFZrVbrldr1fsFhsVjslls1ntFptVrtltt1vuFxuVzul1u13vF5vV7vl9v1/wGBwWDwmFw2HxGJxWLxmNx0xiFdyOTh8Tf9ZymXx+QytcyNgz8r0OblWjyWds+m" +
	"0ka1Vf1ta1+r1mos2xrG2xeZ0+a0W0qOx3GO4NV3WeyvD2XJ5XL5nN51aiw+lfSj0gkUkAEllHanHI5j/cHg8EZf7w8vl8j4f/qfEZeB09/vjLAB30+kZQAP/P5/H6/y" +
	"NAOAEAwCjMBwFAEDwJBMDwLBYAP2/8Hv8/gAGAD8LQs9w/nhDY/oygIA=");
	G2antt1.HeaderAppearance = 4;
	var var_Editor = G2antt1.Columns.Add("Multiple-Columns Tree DropDownListType").Editor;
		var_Editor.EditType = 3;
		var_Editor.DropDownAutoWidth = 0;
		var_Editor.Option(57) = "Name¦Title¦City¦Phone";
		var_Editor.Option(58) = "224¦¦¦96";
		var_Editor.AddItem(1,"Nancy Davolio¦Sales Representative¦Seattle¦(206) 555-9857",1);
		var_Editor.AddItem(2,"Andrew Fuller¦<b>Vice President</b>, Sales¦Tacoma¦(206) 555-9482",2);
		var_Editor.InsertItem(3,"Janet Leverling¦Sales Representative¦Kirkland¦(206) 555-3412",3,2);
		var_Editor.InsertItem(4,"Peacock Margaret¦Sales Representative¦Redmond¦(206) 555-8122",3,2);
		var_Editor.InsertItem(5,"Steven Buchanan¦Sales Manager¦London¦(71) 555-4848",2,2);
		var_Editor.InsertItem(6,"Michael Suyama¦Sales Representative¦London¦(71) 555-7773",1,5);
		var_Editor.InsertItem(7,"Robert King¦Sales Representative¦Kirkland¦(71) 555-5598",2,2);
		var_Editor.InsertItem(8,"Laura Callahan¦Inside Sales Coordinator¦Seattle¦(206) 555-1189",3,2);
		var_Editor.InsertItem(9,"Anne Dodsworth¦Sales Representative¦London¦(71) 555-4444",2,5);
		var_Editor.ExpandAll();
	var var_Items = G2antt1.Items;
		var_Items.AddItem(1);
		var_Items.AddItem(2);
		var_Items.AddItem(4);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2160
Does you control support multiple-columns for a drop down editor

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Chart.PaneWidth(true) = 0;
	G2antt1.HeaderAppearance = 4;
	var var_Editor = G2antt1.Columns.Add("Multiple-Columns DropDownListType").Editor;
		var_Editor.EditType = 3;
		var_Editor.DropDownAutoWidth = 0;
		var_Editor.AddItem(0,"Jollyville¦JV3¦3026N 09746W¦TX",null);
		var_Editor.AddItem(1,"Altamont¦TMO¦4021N 11017W¦UT",null);
		var_Editor.AddItem(2,"Williamston¦IIM¦4241N 08417W¦MI",null);
		var_Editor.AddItem(3,"Merrittstown¦IWN¦3958N 07952W¦PA",null);
		var_Editor.AddItem(4,"Houston¦HOU¦2945N 09521W¦TX",null);
		var_Editor.AddItem(5,"Gales Ferry¦GSF¦4125N 07205W¦CT",null);
	var var_Items = G2antt1.Items;
		var_Items.InsertItem(0,"",1);
		var_Items.InsertItem(0,"",2);
		var_Items.InsertItem(0,"",4);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2159
Is it possible to change the summary-bar's start or/and end margins

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HeaderAppearance = 4;
	G2antt1.LinesAtRoot = 5;
	G2antt1.ColumnAutoResize = false;
	var var_Chart = G2antt1.Chart;
		var_Chart.AllowCreateBar = false;
		var_Chart.AllowLinkBars = false;
		var_Chart.FirstVisibleDate = "1/1/2008";
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(0) = 256;
	G2antt1.Columns.Add("Members").Width = 96;
	var var_Column = G2antt1.Columns.Add("Start");
		var_Column.Width = 112;
		var_Column.Def(18) = 1;
		var_Column.LevelKey = 1;
	var var_Column1 = G2antt1.Columns.Add("End");
		var_Column1.Width = 112;
		var_Column1.Def(18) = 2;
		var_Column1.LevelKey = 1;
	var var_Items = G2antt1.Items;
		var_Items.AllowCellValueToItemBar = true;
		var hR1 = var_Items.AddItem("Team");
		var_Items.AddBar(hR1,"Summary","1/2/2008","1/8/2008","",null);
		var_Items.AddBar(hR1,"","1/13/2008","1/13/2008","R",null);
		var_Items.ItemBar(hR1,"R",19) = 100;
		var_Items.DefineSummaryBars(hR1,"",h1,"R");
		var h1 = var_Items.InsertItem(hR1,null,"Member 1");
		var_Items.AddBar(h1,"Task","1/2/2008","1/7/2008",null,null);
		var_Items.DefineSummaryBars(hR1,"",h1,"");
		h1 = var_Items.InsertItem(hR1,null,"Member 2");
		var_Items.AddBar(h1,"Task","1/4/2008","1/9/2008",null,null);
		var_Items.DefineSummaryBars(hR1,"",h1,"");
		h1 = var_Items.InsertItem(hR1,null,"Member 3");
		var_Items.AddBar(h1,"Task","1/5/2008","1/10/2008",null,null);
		var_Items.DefineSummaryBars(hR1,"",h1,"");
		var_Items.ExpandItem(hR1) = true;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2158
I want to display two lines/curves in the histogram-area such as expected and actual work effor per month. How can I do that (leaf)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Chart = G2antt1.Chart;
		var_Chart.PaneWidth(false) = 128;
		var_Chart.FirstVisibleDate = "10/5/2020";
		var_Chart.HistogramVisible = true;
		var_Chart.HistogramHeight = 96;
		var_Chart.HistogramView = 1808;
		var var_Bar = var_Chart.Bars.Item("Task");
			var_Bar.HistogramPattern = 2048;
			var_Bar.HistogramItems = -4;
			var_Bar.HistogramBorderSize = 1;
		var var_Bar1 = var_Chart.Bars.Copy("Task","C");
			var_Bar1.HistogramPattern = 2048;
			var_Bar1.HistogramItems = -4;
			var_Bar1.HistogramColor = 255;
			var_Bar1.HistogramBorderSize = 2;
	G2antt1.Columns.Add("Column");
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Project A");
		var_Items.AddBar(var_Items.InsertItem(h,null,"Item 1"),"Task","10/7/2020","10/14/2020",null,null);
		var_Items.AddBar(var_Items.InsertItem(h,null,"Item 2"),"Task","10/10/2020","10/17/2020",null,null);
		var_Items.ExpandItem(h) = true;
		h = var_Items.AddItem("Project B");
		var_Items.AddBar(var_Items.InsertItem(h,null,"Item 1"),"C","10/13/2020","10/20/2020",null,null);
		var_Items.AddBar(var_Items.InsertItem(h,null,"Item 2"),"C","10/15/2020","10/23/2020",null,null);
		var_Items.ExpandItem(h) = true;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2157
I want to display two lines/curves in the histogram-area such as expected and actual work effor per month. How can I do that (flat)

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="BarResize(Item,Key)" LANGUAGE="JScript">
	var var_Items = G2antt1.Items;
		var_Items.ItemBar(Item,Key,21) = var_Items.ItemBar(Item,Key,12);
		var_Items.ItemBar(Item,"C",21) = 1;
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HeaderVisible = 1;
	G2antt1.HeaderAppearance = 4;
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "10/5/2020";
		var_Chart.PaneWidth(false) = 128;
		var_Chart.LevelCount = 2;
		var_Chart.HistogramHeight = 96;
		var_Chart.HistogramVisible = true;
		var var_Bar = var_Chart.Bars.Add("Task%Progress");
			var_Bar.HistogramPattern = 2048;
			var_Bar.HistogramItems = -4;
			var_Bar.HistogramBorderSize = 1;
			var_Bar.HistogramBorderColor = var_Bar.Color;
			var_Bar.Shortcut = "P";
			var_Bar.Def(14) = true;
		var var_Bar1 = var_Chart.Bars.Copy("Task","C");
			var_Bar1.HistogramPattern = 2048;
			var_Bar1.HistogramColor = 255;
			var_Bar1.HistogramBorderSize = 2;
	G2antt1.Columns.Add("Tasks").FormatColumn = "`Task ` + (1 index ``)";
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem(null);
		var_Items.AddBar(h,"P","10/7/2020","10/14/2020","P",null);
		var_Items.ItemBar(h,"P",12) = 0.5;
		var_Items.AddBar(h,"C","10/7/2020","10/14/2020","C",null);
		var_Items.ItemBar(h,"C",19) = 100;
		var_Items.GroupBars(h,"P",true,h,"C",true,null,null);
		var_Items.GroupBars(h,"P",false,h,"C",false,null,null);
		h = var_Items.AddItem(null);
		var_Items.AddBar(h,"P","10/10/2020","10/17/2020","P",null);
		var_Items.ItemBar(h,"P",12) = 0.75;
		var_Items.AddBar(h,"C","10/10/2020","10/17/2020","C",null);
		var_Items.ItemBar(h,"C",19) = 100;
		var_Items.GroupBars(h,"P",true,h,"C",true,null,null);
		var_Items.GroupBars(h,"P",false,h,"C",false,null,null);
		h = var_Items.AddItem(null);
		var_Items.AddBar(h,"P","10/13/2020","10/20/2020","P",null);
		var_Items.ItemBar(h,"P",12) = 0.25;
		var_Items.AddBar(h,"C","10/13/2020","10/20/2020","C",null);
		var_Items.ItemBar(h,"C",19) = 100;
		var_Items.GroupBars(h,"P",true,h,"C",true,null,null);
		var_Items.GroupBars(h,"P",false,h,"C",false,null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2156
Is it possible to show the filterbar on top of the rows

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.FilterBarPromptVisible = 8192;
	G2antt1.HeaderHeight = 24;
	G2antt1.FilterBarHeight = G2antt1.HeaderHeight;
	G2antt1.HeaderAppearance = 1;
	G2antt1.DrawGridLines = -1;
	G2antt1.GridLineStyle = 512;
	var var_Column = G2antt1.Columns.Add("Column");
		var_Column.DisplayFilterButton = true;
		var_Column.FilterType = 3;
		var_Column.Filter = "B*";
	var var_Column1 = G2antt1.Columns.Add("Index");
		var_Column1.FormatColumn = "1 index ``";
		var_Column1.Position = 0;
		var_Column1.Width = 48;
		var_Column1.AllowSizing = false;
		var_Column1.SortType = 1;
		var_Column1.Def(0) = true;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("A.1");
		var_Items.AddItem("A.2");
		var_Items.AddItem("B.1");
		var_Items.AddItem("B.2");
		var_Items.AddItem("B.3");
		var_Items.AddItem("C");
	G2antt1.ApplyFilter();
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2155
The deadline symbol is now a white arrow and it is difficult to see. I want to create a green or black arrow for showing deadline

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Task");
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.PaneWidth(false) = 96;
		var var_Bar = var_Chart.Bars.Item("Deadline");
			var_Bar.StartColor = 32768;
			var_Bar.StartShape = 12;
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem("Task"),"Deadline","1/2/2001","1/2/2001",null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2154
DragDrop (with visual effect)

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="OLEDragDrop(Data,Effect,Button,Shift,X,Y)" LANGUAGE="JScript">
	// SelectItem(InsertItem(i,, Data.GetData(1))) = True
	var i = G2antt1.ItemFromPoint(-1,-1,c,hit);
	var var_Items = G2antt1.Items;
		var_Items.ExpandItem(i) = true;
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="OLEStartDrag(Data,AllowedEffects)" LANGUAGE="JScript">
	// Data.SetData(Me.Items.CellCaption(FocusItem, 0), 1)
	AllowedEffects = 1;
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.VisualAppearance.Add(1,"gBFLBCJwBAEHhEJAAEhABPUIQAAYAQGKIcBiAKBQAGaAoDgYN4MAANAwjJBMKgBBCLIxhEYobgmGIaRjEEQDCKYcxHCaIBiGcaIfDEBIeSBHcgRbAcOQHGSZZBhGRJG" +
	"juKIbSrLICzBDUcRnGwAKQoaaaEomHwyAZOYwDAIoWhpKKCKjqWJKNb+XgAAJTES0RRVRTNAZ1YghGAQgIA==");
	G2antt1.Background(96) = 16777216;
	G2antt1.Background(97) = 1;
	G2antt1.Background(33) = 0;
	G2antt1.Background(34) = 16777215;
	G2antt1.OLEDropMode = 1;
	G2antt1.AutoDrag = 196608;
	G2antt1.LinesAtRoot = -1;
	G2antt1.Indent = 16;
	G2antt1.SelBackMode = 1;
	G2antt1.Columns.Add("Default");
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Root");
		var_Items.InsertItem(h,null,"Child 1");
		var_Items.InsertItem(h,null,"Child 2");
		var_Items.ExpandItem(h) = true;
	alert( "You can:" );
	alert( "A) left-click to drag and drop items between controls (open a new exhelper and run the same sample)" );
	alert( "B) right-click to re-arrange the item position inside the same control" );
	alert( "This sample shows how you can insert the data being dropped as a child of the item being hovered." );
}
</SCRIPT>
</BODY>

2153
DragDrop (with no visual effect, hide item while drag and drop)

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="OLEDragDrop(Data,Effect,Button,Shift,X,Y)" LANGUAGE="JScript">
	// SelectItem(InsertItem(i,, Data.GetData(1))) = True
	var i = G2antt1.ItemFromPoint(-1,-1,c,hit);
	var var_Items = G2antt1.Items;
		var_Items.ExpandItem(i) = true;
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="OLEStartDrag(Data,AllowedEffects)" LANGUAGE="JScript">
	// Data.SetData(Me.Items.CellCaption(FocusItem, 0), 1)
	AllowedEffects = 1;
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.Background(33) = 0;
	G2antt1.Background(34) = 16777215;
	G2antt1.OLEDropMode = 1;
	G2antt1.AutoDrag = 196608;
	G2antt1.LinesAtRoot = -1;
	G2antt1.Indent = 16;
	G2antt1.SelBackMode = 1;
	G2antt1.Columns.Add("Default");
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Root");
		var_Items.InsertItem(h,null,"Child 1");
		var_Items.InsertItem(h,null,"Child 2");
		var_Items.ExpandItem(h) = true;
	alert( "You can:" );
	alert( "A) left-click to drag and drop items between controls (open a new exhelper and run the same sample)" );
	alert( "B) right-click to re-arrange the item position inside the same control" );
	alert( "This sample shows how you can insert the data being dropped as a child of the item being hovered." );
}
</SCRIPT>
</BODY>

2152
DragDrop

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="OLEDragDrop(Data,Effect,Button,Shift,X,Y)" LANGUAGE="JScript">
	// SelectItem(InsertItem(i,, Data.GetData(1))) = True
	var i = G2antt1.ItemFromPoint(-1,-1,c,hit);
	var var_Items = G2antt1.Items;
		var_Items.ExpandItem(i) = true;
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="OLEStartDrag(Data,AllowedEffects)" LANGUAGE="JScript">
	// Data.SetData(Me.Items.CellCaption(FocusItem, 0), 1)
	AllowedEffects = 1;
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.OLEDropMode = 1;
	G2antt1.AutoDrag = 196608;
	G2antt1.LinesAtRoot = -1;
	G2antt1.Indent = 16;
	G2antt1.SelBackMode = 1;
	G2antt1.Columns.Add("Default");
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Root");
		var_Items.InsertItem(h,null,"Child 1");
		var_Items.InsertItem(h,null,"Child 2");
		var_Items.ExpandItem(h) = true;
	alert( "You can:" );
	alert( "A) left-click to drag and drop items between controls (open a new exhelper and run the same sample)" );
	alert( "B) right-click to re-arrange the item position inside the same control" );
	alert( "This sample shows how you can insert the data being dropped as a child of the item being hovered." );
}
</SCRIPT>
</BODY>

2151
Is there anyway to stop the header changing colour when the mouse hovers/moves across the column header (non-clickable)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HeaderAppearance = 4;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Item");
		var var_Column = var_Columns.Add("Pos");
			var_Column.Position = 0;
			var_Column.Width = 32;
			var_Column.AllowSizing = false;
			var_Column.FormatColumn = "1 index ``";
			var_Column.AllowSort = false;
			var_Column.AllowDragging = false;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("Item A");
		var_Items.AddItem("Item B");
		var_Items.AddItem("Item C");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2150
Is there anyway to stop the header changing colour when the mouse hovers/moves across the column header

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HeaderAppearance = 4;
	G2antt1.Background(32) = -1;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Item");
		var var_Column = var_Columns.Add("Pos");
			var_Column.Position = 0;
			var_Column.Width = 32;
			var_Column.AllowSizing = false;
			var_Column.FormatColumn = "1 index ``";
			var_Column.AllowSort = false;
			var_Column.AllowDragging = false;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("Item A");
		var_Items.AddItem("Item B");
		var_Items.AddItem("Item C");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2149
How can I detect the last visible item
<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="SelectionChanged()" LANGUAGE="JScript">
	var var_Items = G2antt1.Items;
		alert( var_Items.NextVisibleItem(var_Items.FocusItem) );
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.LinesAtRoot = -1;
	G2antt1.AutoDrag = 3;
	G2antt1.Columns.Add("Column");
	var var_Items = G2antt1.Items;
		var_Items.InsertItem(var_Items.AddItem("Item 1"),null,"Child 1");
		var_Items.AddItem("Item 2");
		var_Items.AddItem("Item 3");
		var_Items.InsertItem(var_Items.AddItem("Item 4"),null,"Child 4");
		var_Items.AddItem("Item 5");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2148
Is it possible to show the non-working part on the back (behind the item's background)

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="CellStateChanged(Item,ColIndex)" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.LinesAtRoot = 5;
	G2antt1.SelBackMode = 1;
	G2antt1.DefaultItemHeight = 22;
	G2antt1.GridLineStyle = 48;
	G2antt1.DrawGridLines = -1;
	G2antt1.HeaderVisible = 1;
	G2antt1.HeaderAppearance = 4;
	var var_Column = G2antt1.Columns.Add("Tasks");
		var_Column.Def(0) = true;
		var_Column.PartialCheck = true;
	var var_Appearance = G2antt1.VisualAppearance;
		var_Appearance.Add(2,"gBFLBCJwBAEHhEJAAEhABUkIQAAYAQGKIcBiAKBQAGYBIJDEMQ3DjAUBjMK4ZwTC4AIQjCK4JDKHYJRpHEZgLBMJAAGIZYhhUYRUiYMkiJBGGDIDiGGI2SJAcbTVIEc" +
	"x9EyUJSgSTJOjCMokTTIU4TTLYASbJafJJhWSaAiyMouDIOMg1BDNIw/Hika6jOgKUisNJXRzWIBTbDlOQ3JqnbCjOQRSrQBoNDAMAiiaKlbwJPK9RoieQXfwUAJrXJc" +
	"FqXFSLVxNBKAQEBA=");
		var_Appearance.Add(4,"gBFLBCJwBAEHhEJAAEhABTcIQAAYAQGKIcBiAKBQAGaAoDgYN4MAANAwjJBMKgBBCLIxhEYobgmGIaRiBMIxAKIZhzEiJYgGIZxYh8MQER5IEbyBDsBw5AaZZojGRJG" +
	"igNIqSxLUhTRKUdQrG4AKQnGhpDgmJYnU5EcrSUKQcw/JaiKYpGZYXpqO5OTzUIyVHDdKgFGKNKwjKiKKp6FofDJcADUcKAYBKFoaLjgS5bXhSGpnV5bFoWdLTVwhBKA" +
	"QEBA=");
		var_Appearance.Add(1,"CP:2 1 1 -1 -1");
		var_Appearance.Add(3,"CP:4 1 1 -1 -1");
	var var_ConditionalFormat = G2antt1.ConditionalFormats.Add("%CS0 = 1",null);
		var_ConditionalFormat.BackColor = 50331648;
		var_ConditionalFormat.ChartBackColor = var_ConditionalFormat.BackColor;
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "8/1/2017";
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(false) = 128;
		var_Chart.Bars.Item("Task").Pattern = 1;
		var var_Bar = var_Chart.Bars.Item("Summary");
			var_Bar.StartShape = 0;
			var_Bar.EndShape = 0;
			var_Bar.Shape = 4;
		var_Chart.SelBackColor = G2antt1.SelBackColor;
		var_Chart.SelBarColor = 8421504;
		var_Chart.DrawGridLines = -1;
		var_Chart.NonworkingDaysPattern = 1;
		var_Chart.GridLineStyle = 304;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Project");
		var hChild = var_Items.InsertItem(h,null,"Task 1");
		var_Items.AddBar(hChild,"Task","8/2/2017","8/8/2017",null,null);
		var_Items.SelectItem(hChild) = true;
		hChild = var_Items.InsertItem(h,null,"Task 2");
		var_Items.AddBar(hChild,"Task","8/3/2017","8/10/2017",null,null);
		hChild = var_Items.InsertItem(h,null,"Task 3");
		var_Items.AddBar(hChild,"Task","8/4/2017","8/12/2017",null,null);
		var_Items.CellState(hChild,0) = 1;
		hChild = var_Items.InsertItem(h,null,"Task 4");
		var_Items.AddBar(hChild,"Task","8/5/2017","8/14/2017",null,null);
		hChild = var_Items.InsertItem(h,null,"Task 5");
		var_Items.AddBar(hChild,"Task","8/6/2017","8/16/2017",null,null);
		var_Items.AddBar(h,"Summary","8/1/2017","8/1/2017","sum",null);
		var_Items.DefineSummaryBars(h,"sum",-3,"");
		var_Items.ExpandItem(h) = true;
		h = var_Items.AddItem("ItemBackColor");
		var_Items.AddBar(h,"Progress","8/4/2017","8/14/2017",null,null);
		var_Items.ItemBackColor(h) = 25198847;
		G2antt1.Chart.ItemBackColor(h) = 25198847;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2147
How can I hide a bar within the control's overview (sample 1)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Default");
	G2antt1.Background(18) = 12500670;
	G2antt1.BackColorLevelHeader = G2antt1.BackColor;
	var var_Chart = G2antt1.Chart;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(false) = 64;
		var_Chart.OverviewHeight = 48;
		var_Chart.OverviewVisible = 73730;
		var_Chart.FirstVisibleDate = "1/1/2020";
		var_Chart.Bars.Copy("Task","TaskO").Color = 255;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("");
		var h = var_Items.AddItem("");
		var_Items.AddBar(h,"Task","1/2/2020","1/12/2020","K1",null);
		var_Items.AddBar(h,"Task","12/2/2020","12/12/2020","K2",null);
		h = var_Items.AddItem("");
		var_Items.AddBar(h,"TaskO","1/2/2020","1/12/2020","K1",null);
		var_Items.ItemBar(h,"K1",41) = -1;
		var_Items.AddBar(h,"TaskO","12/2/2020","12/12/2020","K2",null);
		var_Items.ItemBar(h,"K2",41) = -1;
		h = var_Items.AddItem("");
		var_Items.AddBar(h,"Task","1/2/2020","1/12/2020","K1",null);
		var_Items.AddBar(h,"Task","12/2/2020","12/12/2020","K2",null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2146
How can I hide all bars within the control's overview (sample 2)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Default");
	G2antt1.Background(18) = 12500670;
	G2antt1.BackColorLevelHeader = G2antt1.BackColor;
	var var_Chart = G2antt1.Chart;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(false) = 64;
		var_Chart.OverviewHeight = 48;
		var_Chart.OverviewVisible = 8705;
		var_Chart.FirstVisibleDate = "1/1/2020";
		var var_Bar = var_Chart.Bars.Copy("Task","TaskO");
			var_Bar.OverviewColor = -1;
			var_Bar.Color = 255;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("");
		var h = var_Items.AddItem("");
		var_Items.AddBar(h,"Task","1/2/2020","1/12/2020","K1",null);
		var_Items.AddBar(h,"Task","12/2/2020","12/12/2020","K2",null);
		h = var_Items.AddItem("");
		var_Items.AddBar(h,"TaskO","1/2/2020","1/12/2020","K1",null);
		var_Items.AddBar(h,"TaskO","12/2/2020","12/12/2020","K2",null);
		h = var_Items.AddItem("");
		var_Items.AddBar(h,"Task","1/2/2020","1/12/2020","K1",null);
		var_Items.AddBar(h,"Task","12/2/2020","12/12/2020","K2",null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2145
How can I hide all bars or specified type within the control's overview (sample 3)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Default");
	G2antt1.Background(18) = 12500670;
	G2antt1.BackColorLevelHeader = G2antt1.BackColor;
	var var_Chart = G2antt1.Chart;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(false) = 64;
		var_Chart.OverviewHeight = 48;
		var_Chart.OverviewVisible = 73730;
		var_Chart.FirstVisibleDate = "1/1/2020";
		var var_Bar = var_Chart.Bars.Copy("Task","TaskO");
			var_Bar.OverviewColor = -1;
			var_Bar.Color = 255;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("");
		var h = var_Items.AddItem("");
		var_Items.AddBar(h,"Task","1/2/2020","1/12/2020","K1",null);
		var_Items.AddBar(h,"Task","12/2/2020","12/12/2020","K2",null);
		h = var_Items.AddItem("");
		var_Items.AddBar(h,"TaskO","1/2/2020","1/12/2020","K1",null);
		var_Items.AddBar(h,"TaskO","12/2/2020","12/12/2020","K2",null);
		h = var_Items.AddItem("");
		var_Items.AddBar(h,"Task","1/2/2020","1/12/2020","K1",null);
		var_Items.AddBar(h,"Task","12/2/2020","12/12/2020","K2",null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2144
Is it possible to exclude the parent/child items when do the filtering, so to include only items that match the filter without any indentation

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="AddItem(Item)" LANGUAGE="JScript">
	G2antt1.Items.AddBar(Item,"Task","1/2/2001","1/9/2001",null,null);
</SCRIPT>

<SCRIPT FOR="G2antt1" EVENT="FilterChange()" LANGUAGE="JScript">
	G2antt1.Indent = G2antt1.FormatABC("value > 0 ? 18 : 0",.Items.MatchItemCount,null,null);
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.LinesAtRoot = -1;
	G2antt1.Indent = 18;
	G2antt1.FilterInclude = 4;
	G2antt1.DrawGridLines = 2;
	G2antt1.HeaderAppearance = 1;
	var var_Chart = G2antt1.Chart;
		var_Chart.LevelCount = 2;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.PaneWidth(false) = 164;
	var var_Columns = G2antt1.Columns;
		var var_Column = var_Columns.Add("Column");
			var_Column.DisplayFilterButton = true;
			var_Column.FilterType = 240;
			var_Column.FilterList = 256;
			var_Column.Filter = "C1";
		var var_Column1 = var_Columns.Add("Pos");
			var_Column1.FormatColumn = "1 rindex ``";
			var_Column1.Position = 0;
			var_Column1.AllowSizing = false;
			var_Column1.AllowDragging = false;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("R1");
		var h2 = var_Items.InsertItem(h,null,"S");
		var_Items.InsertItem(h2,null,"C1");
		var_Items.InsertItem(h2,null,"C2");
		var_Items.InsertItem(h,null,"C1");
		var_Items.InsertItem(h,null,"C2");
		var_Items.ExpandItem(h) = true;
		h = var_Items.AddItem("R2");
		var_Items.InsertItem(h,null,"C1");
		var_Items.InsertItem(h,null,"C2");
	G2antt1.ApplyFilter();
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2143
I am using the Chart.AllowResizeChart property. How can I customize the labels into the chart's levels
<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Task");
	var var_Chart = G2antt1.Chart;
		var_Chart.AllowResizeChart = 262;
		var_Chart.Label(0) = "year";
		var_Chart.Label(1) = "";
		var_Chart.Label(2) = "";
		var_Chart.Label(16) = "month";
		var_Chart.Label(17) = "";
		var_Chart.Label(256) = "week";
		var_Chart.Label(4096) = "day";
		var_Chart.Label(65536) = "hour";
		var_Chart.Label(1048576) = "";
		var_Chart.Label(16777216) = "";
		var_Chart.ShowNonworkingDates = false;
		var_Chart.LevelCount = 2;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.PaneWidth(false) = 48;
		var_Chart.UnitWidth = 32;
		var_Chart.UnitScale = 4096;
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem("Task A"),"Task","1/2/2001","1/6/2001","K1",null);
		var_Items.AddBar(var_Items.AddItem("Task B"),"Task","1/6/2001","1/10/2001","K1",null);
		var_Items.AddBar(var_Items.AddItem("Task C"),"Task","1/10/2001","1/14/2001","K1",null);
		var_Items.AddBar(var_Items.AddItem(""),"","1/8/2001","1/8/2001","Info","Click the <b>middle</b> mouse button and start dragging");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2142
Is it possible to display the header using multiple lines, while chart display multiple levels (sample 2)

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="AddColumn(Column)" LANGUAGE="JScript">
	// Column.Def(52) = 4
	// Column.Def(53) = 4
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Chart = G2antt1.Chart;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(true) = 256;
	G2antt1.HeaderVisible = 1;
	G2antt1.HeaderAppearance = 1;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Column");
		var_Columns.Add("C1").HTMLCaption = "<b>C<off 4>1</b><br>left";
		var_Columns.Add("C2").HTMLCaption = "<c><b>C<off 4>2</b><br><c>center";
		var_Columns.Add("C3").HTMLCaption = "<r><b>C<off 4>3</b><br><r>right";
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2141
Is there any way to control the z-order of a TimeZone

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	var var_Chart = G2antt1.Chart;
		var_Chart.PaneWidth(false) = 0;
		var_Chart.UnitWidth = 15;
		var_Chart.LevelCount = 2;
		var_Chart.FirstVisibleDate = "12/28/2009";
		var_Chart.MarkTimeZone("Top","1/1/2010","1/5/2010",16711680,"1;;<fgcolor=FFFFFF>Top;1");
		var_Chart.MarkTimeZone("Partial","1/8/2010","1/12/2010",16711680,"50;;<fgcolor=FFFFFF>Partial;1");
		var_Chart.MarkTimeZone("Default","1/15/2010","1/19/2010",16711680,";;<fgcolor=FFFFFF>Default;1");
}
</SCRIPT>
</BODY>

2140
Is it possible to display the header using multiple lines, while chart display multiple levels (sample 1)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Chart.LevelCount = 2;
	G2antt1.HeaderHeight = 18;
	G2antt1.HeaderSingleLine = false;
	G2antt1.HeaderVisible = 1;
	G2antt1.Columns.Add("This is just a column that should break the header.").Width = 32;
	G2antt1.Columns.Add("This is just another column that should break the header.");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2139
Difference between HistogramValueFromPoint and HistogramValue (sample 2)

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="MouseMove(Button,Shift,X,Y)" LANGUAGE="JScript">
	var var_Chart = G2antt1.Chart;
		var v1 = var_Chart.HistogramValueFromPoint(-1,-1);
		var v2 = var_Chart.HistogramValue(var_Chart.DateFromPoint(-1,-1),null,null);
		var vMin = var_Chart.HistogramValue("min",null,null);
		var vMax = var_Chart.HistogramValue("max",null,null);
	var format = G2antt1.FormatABC("`<b>ValueFromPoint</b>: ` + A + `<br>ValueFromDate: ` + B",v1,v2,null);
	format = G2antt1.FormatABC("A  + `<br>Min: ` + B + `<br>Max: ` + C",format,vMin,vMax);
	G2antt1.ShowToolTip(format,null,null,"16","16");
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Tasks");
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstWeekDay = 1;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(0) = 40;
		var_Chart.FirstVisibleDate = "6/9/2005";
		var_Chart.HistogramVisible = true;
		var_Chart.HistogramView = 8304;
		var_Chart.HistogramHeight = 128;
		var var_Bar = var_Chart.Bars.Item("Task");
			var_Bar.HistogramPattern = var_Bar.Pattern;
			var_Bar.HistogramType = 256;
			var_Bar.HistogramItems = -6;
			var_Bar.HistogramRulerLinesColor = 65536;
			var_Bar.HistogramBorderSize = 1;
			var_Bar.HistogramBorderColor = 65536;
			var_Bar.HistogramCumulativeOriginalColorBars = 0;
			var_Bar.HistogramCumulativeShowLegend = -1;
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem("Task"),"Task","6/10/2005","6/14/2005","",null);
		var_Items.AddBar(var_Items.AddItem("Task"),"Task","6/11/2005","6/15/2005","",null);
		var_Items.AddBar(var_Items.AddItem("Task"),"Task","6/12/2005","6/16/2005","",null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2138
Difference between HistogramValueFromPoint and HistogramValue (sample 1)

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="MouseMove(Button,Shift,X,Y)" LANGUAGE="JScript">
	var var_Chart = G2antt1.Chart;
		var v1 = var_Chart.HistogramValueFromPoint(-1,-1);
		var v2 = var_Chart.HistogramValue(var_Chart.DateFromPoint(-1,-1),null,null);
		var vMin = var_Chart.HistogramValue("min",null,null);
		var vMax = var_Chart.HistogramValue("max",null,null);
	var format = G2antt1.FormatABC("`<b>ValueFromPoint</b>: ` + A + `<br>ValueFromDate: ` + B",v1,v2,null);
	format = G2antt1.FormatABC("A  + `<br>Min: ` + B + `<br>Max: ` + C",format,vMin,vMax);
	G2antt1.ShowToolTip(format,null,null,"16","16");
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Tasks");
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstWeekDay = 1;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(0) = 40;
		var_Chart.FirstVisibleDate = "6/9/2005";
		var_Chart.HistogramVisible = true;
		var_Chart.HistogramView = 112;
		var_Chart.HistogramHeight = 128;
		var var_Bar = var_Chart.Bars.Item("Task");
			var_Bar.HistogramPattern = var_Bar.Pattern;
			var_Bar.HistogramType = 0;
			var_Bar.HistogramItems = -6;
			var_Bar.HistogramRulerLinesColor = 65536;
			var_Bar.HistogramBorderSize = 1;
			var_Bar.HistogramBorderColor = 65536;
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem("Task"),"Task","6/10/2005","6/14/2005","",null);
		var_Items.AddBar(var_Items.AddItem("Task"),"Task","6/11/2005","6/15/2005","",null);
		var_Items.AddBar(var_Items.AddItem("Task"),"Task","6/12/2005","6/16/2005","",null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2137
I am using the Inside-Zoom feature, but the inside grid lines are more dashed the dotted

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Chart = G2antt1.Chart;
		var_Chart.UnitScale = 4096;
		var_Chart.PaneWidth(0) = 0;
		var_Chart.LevelCount = 2;
		var_Chart.FirstVisibleDate = "1/1/2008";
		var var_InsideZoomFormat = var_Chart.DefaultInsideZoomFormat;
			var_InsideZoomFormat.InsideLabel = "<%hh%>";
			var_InsideZoomFormat.InsideUnit = 65536;
			var_InsideZoomFormat.InsideCount = 8;
			var_InsideZoomFormat.GridLineStyle = 512;
		var_Chart.AllowInsideZoom = true;
		var var_InsideZooms = var_Chart.InsideZooms;
			var_InsideZooms.Add("1/4/2008");
		var_Chart.DrawGridLines = 2;
		var_Chart.ShowNonworkingDates = false;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2136
I am using expressions for exBarEffort, but the histogram does not show correctly the data

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HeaderVisible = 1;
	G2antt1.HeaderAppearance = 4;
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "10/5/2020";
		var_Chart.PaneWidth(false) = 128;
		var_Chart.LevelCount = 2;
		var_Chart.HistogramHeight = 96;
		var_Chart.HistogramVisible = true;
		var_Chart.AllowInsideZoom = true;
		var_Chart.DrawGridLines = -1;
		var var_InsideZoom = var_Chart.InsideZooms.Add("10/7/2020");
			var_InsideZoom.Width = 196;
		var_Chart.DefaultInsideZoomFormat.GridLineStyle = 48;
		var var_Bar = var_Chart.Bars.Item("Task");
			var_Bar.HistogramPattern = var_Bar.Pattern;
			var_Bar.Def(3) = "<%=%0%>";
			var_Bar.Def(4) = 18;
			var_Bar.Def(21) = "(hour(value) > 5 and hour(value) < 18) ? 2 : 0";
		var_Chart.HistogramUnitScale = 65536;
	G2antt1.Columns.Add("Tasks").FormatColumn = "`Task ` + (1 index ``)";
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem(""),"Task","10/7/2020","10/12/2020",null,null);
		var_Items.AddBar(var_Items.AddItem(""),"Task","10/8/2020","10/13/2020",null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2135
How can I specify the z-order of bars to be shown within the chart's histogram

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HeaderVisible = 1;
	G2antt1.HeaderAppearance = 4;
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "10/5/2020";
		var_Chart.PaneWidth(false) = 128;
		var_Chart.LevelCount = 2;
		var_Chart.HistogramHeight = 96;
		var_Chart.HistogramVisible = true;
		var var_Bar = var_Chart.Bars.Add("A");
			var_Bar.Color = 16711680;
			var_Bar.HistogramPattern = 1;
			var_Bar.HistogramItems = -6;
			var_Bar.HistogramCumulativeOriginalColorBars = 1;
			var_Bar.Def(3) = "<%=%0%>";
			var_Bar.Def(4) = 18;
		var var_Bar1 = var_Chart.Bars.Copy("A","B");
			var_Bar1.Color = 65280;
			var_Bar1.HistogramCumulativeOriginalColorBars = 1;
			var_Bar1.Def(3) = "<%=%0%>";
			var_Bar1.Def(4) = 18;
		var_Chart.HistogramView = 8304;
		var_Chart.HistogramZOrder = "A,B";
	G2antt1.Columns.Add("Tasks").FormatColumn = "`Task ` + (1 index ``)";
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem(""),"A","10/7/2020","10/12/2020",null,null);
		var_Items.AddBar(var_Items.AddItem(""),"A","10/8/2020","10/13/2020",null,null);
		var_Items.AddBar(var_Items.AddItem(""),"B","10/9/2020","10/14/2020",null,null);
		var_Items.AddBar(var_Items.AddItem(""),"B","10/10/2020","10/15/2020",null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2134
How can I show cumulative histogram for two or more different types of bars

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.HeaderVisible = 1;
	G2antt1.HeaderAppearance = 4;
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "10/5/2020";
		var_Chart.PaneWidth(false) = 128;
		var_Chart.LevelCount = 2;
		var_Chart.HistogramHeight = 96;
		var_Chart.HistogramVisible = true;
		var var_Bar = var_Chart.Bars.Add("A");
			var_Bar.Color = 16711680;
			var_Bar.HistogramPattern = 1;
			var_Bar.HistogramItems = -6;
			var_Bar.HistogramCumulativeOriginalColorBars = 1;
			var_Bar.Def(3) = "<%=%0%>";
			var_Bar.Def(4) = 18;
		var var_Bar1 = var_Chart.Bars.Copy("A","B");
			var_Bar1.Color = 65280;
			var_Bar1.HistogramCumulativeOriginalColorBars = 1;
			var_Bar1.Def(3) = "<%=%0%>";
			var_Bar1.Def(4) = 18;
		var_Chart.HistogramView = 8304;
	G2antt1.Columns.Add("Tasks").FormatColumn = "`Task ` + (1 index ``)";
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem(""),"A","10/7/2020","10/12/2020",null,null);
		var_Items.AddBar(var_Items.AddItem(""),"A","10/8/2020","10/13/2020",null,null);
		var_Items.AddBar(var_Items.AddItem(""),"B","10/9/2020","10/14/2020",null,null);
		var_Items.AddBar(var_Items.AddItem(""),"B","10/10/2020","10/15/2020",null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2133
I would like to display a solid line between "root" items, and dotted lines (default) between child items. How can I do that

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.LinesAtRoot = -1;
	G2antt1.DrawGridLines = 1;
	G2antt1.GridLineStyle = 512;
	G2antt1.VisualAppearance.Add(1,"gBFLBCJwBAEHhEJAAEhABMsIQAAYAQGKIcBiAKBQAGaAoDgYN4MAANAwjJBMKgBBCLIxhEYobgmGIXRpFMbxAKQahLEiTIgGUYJHgmK4tQLHb7zGAABRDDSOIDnGQJX" +
	"haI4JQSMMQDGLAZxVFiPRhAWLpBh+PQATrOdLUfSjVwhBKAQEBA==");
	var var_Column = G2antt1.Columns.Add("Default");
		var_Column.Def(0) = true;
		var_Column.PartialCheck = true;
	var var_Column1 = G2antt1.Columns.Add("Position");
		var_Column1.FormatColumn = "((1 rindex ``) contains `.`) = 0";
		var_Column1.Visible = false;
	var var_ConditionalFormat = G2antt1.ConditionalFormats.Add("%C1",null);
		var_ConditionalFormat.BackColor = 31514848;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Root 1");
		var_Items.InsertItem(h,null,"Child 1");
		var_Items.InsertItem(h,null,"Child 2");
		var_Items.InsertItem(h,null,"Child 3");
		var_Items.ExpandItem(h) = true;
		h = var_Items.AddItem("Root 2");
		var_Items.InsertItem(h,null,"Child 1");
		var_Items.InsertItem(h,null,"Child 2");
		h = var_Items.AddItem("Root 3");
		var_Items.InsertItem(h,null,"Child 1");
		var_Items.InsertItem(h,null,"Child 2");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2132
I can not center or align the cell's caption and icon, when it displays the hierarchy

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Images("gBJJgBAIDAAGAAEAAQhYAf8Pf4hh0QihCJo2AEZjQAjEZFEaIEaEEaAIAkcbk0olUrlktl0vmExmUzmk1m03nE5nU7nk9n0/oFBoVDolFo1HpFJpVLplNp1PqFRqVTq" +
	"lVq1XrFZrVbrldr1fsFhsVjslls1ntFptVrtltt1vuFxuVzul1u13vF5vV7vl9v1/wGBwWDwmFw2HxGJxWLxmNx0xiFdyOTh8Tf9ZymXx+QytcyNgz8r0OblWjyWds+m" +
	"0ka1Vf1ta1+r1mos2xrG2xeZ0+a0W0qOx3GO4NV3WeyvD2XJ5XL5nN51aiw+lfSj0gkUkAEllHanHI5j/cHg8EZf7w8vl8j4f/qfEZeB09/vjLAB30+kZQAP/P5/H6/y" +
	"NAOAEAwCjMBwFAEDwJBMDwLBYAP2/8Hv8/gAGAD8LQs9w/nhDY/oygIA=");
	var var_Column = G2antt1.Columns.Add("Tasks");
		var_Column.Def(17) = 1;
	G2antt1.HeaderVisible = 1;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Project");
		var hChild = var_Items.InsertItem(h,null,"<img>1</img> Task (left)");
		hChild = var_Items.InsertItem(h,null,"<c><img>2</img> Task (center)");
		hChild = var_Items.InsertItem(h,null,"<r>Task (right) <img>3</img>");
		var_Items.ExpandItem(h) = true;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2131
How do I mask for float/integer number

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.ColumnAutoResize = true;
	G2antt1.Columns.Add("Type").Width = 32;
	G2antt1.Columns.Add("Editor");
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Integer");
		var_Items.CellValue(h,1) = "12";
		var var_Editor = var_Items.CellEditor(h,1);
			var_Editor.EditType = 1;
			var_Editor.Numeric = -1;
		h = var_Items.AddItem("Integer (mask, group)");
		var_Items.CellValue(h,1) = "10002";
		var_Items.FormatCell(h,1) = "value format `0||`";
		var var_Editor1 = var_Items.CellEditor(h,1);
			var_Editor1.EditType = 8;
			var_Editor1.Mask = ";;;float,digits=0,invalid=empty,warning=invalid character";
		h = var_Items.AddItem("Integer (mask, no group)");
		var_Items.CellValue(h,1) = "10002";
		var_Items.FormatCell(h,1) = "value format `0|0|`";
		var var_Editor2 = var_Items.CellEditor(h,1);
			var_Editor2.EditType = 8;
			var_Editor2.Mask = ";;;float,digits=0,grouping=,invalid=empty,warning=invalid character";
		h = var_Items.AddItem("Float");
		var_Items.CellValue(h,1) = "+12.34E+2";
		var var_Editor3 = var_Items.CellEditor(h,1);
			var_Editor3.EditType = 1;
			var_Editor3.Numeric = 1;
		h = var_Items.AddItem("Float (no signs)");
		var_Items.CellValue(h,1) = "12.34E-2";
		var var_Editor4 = var_Items.CellEditor(h,1);
			var_Editor4.EditType = 1;
			var_Editor4.Numeric = 769;
		h = var_Items.AddItem("Float-Integer");
		var_Items.CellValue(h,1) = "+12.34";
		var var_Editor5 = var_Items.CellEditor(h,1);
			var_Editor5.EditType = 1;
			var_Editor5.Numeric = 2;
		h = var_Items.AddItem("Float-Integer (no signs)");
		var_Items.CellValue(h,1) = "12.34";
		var var_Editor6 = var_Items.CellEditor(h,1);
			var_Editor6.EditType = 1;
			var_Editor6.Numeric = 770;
		h = var_Items.AddItem("Float (mask,group)");
		var_Items.CellValue(h,1) = "10002.34";
		var_Items.FormatCell(h,1) = "value format `2`";
		var var_Editor7 = var_Items.CellEditor(h,1);
			var_Editor7.EditType = 8;
			var_Editor7.Mask = ";;;float,invalid=empty,warning=invalid character";
		h = var_Items.AddItem("Float (mask, no group)");
		var_Items.CellValue(h,1) = "10002.34";
		var_Items.FormatCell(h,1) = "value format `2|0|`";
		var var_Editor8 = var_Items.CellEditor(h,1);
			var_Editor8.EditType = 8;
			var_Editor8.Mask = ";;;float,grouping=,invalid=empty,warning=invalid character";
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2130
Is it possible to offset (horizontally) the bar's caption

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("HOffset");
	G2antt1.HeaderAppearance = 1;
	G2antt1.ScrollBySingleLine = true;
	G2antt1.DrawGridLines = -2;
	var var_Chart = G2antt1.Chart;
		var_Chart.DrawGridLines = -2;
		var_Chart.FirstVisibleDate = "12/16/2000";
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(false) = 128;
		var var_Bar = var_Chart.Bars.Item("Task");
			var_Bar.Pattern = 32;
			var_Bar.Color = 10790052;
			var_Bar.StartColor = 15790320;
			var_Bar.EndColor = var_Bar.StartColor;
			var_Bar.Height = 15;
			var_Bar.Def(3) = "label";
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("right");
		var_Items.AddBar(h,"Task","12/22/2000","12/27/2000",null,null);
		var_Items.ItemBar(h,"",4) = 2;
		h = var_Items.AddItem("right - 4");
		var_Items.AddBar(h,"Task","12/22/2000","12/27/2000",null,null);
		var_Items.ItemBar(h,"",4) = 2;
		var_Items.ItemBar(h,"",58) = -4;
		h = var_Items.AddItem("left");
		var_Items.AddBar(h,"Task","12/22/2000","12/27/2000",null,null);
		var_Items.ItemBar(h,"",4) = 0;
		h = var_Items.AddItem("left + 4");
		var_Items.AddBar(h,"Task","12/22/2000","12/27/2000",null,null);
		var_Items.ItemBar(h,"",4) = 0;
		var_Items.ItemBar(h,"",58) = 4;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2129
Is it possible to always center the bar's caption (even if the item-bar is partially visible)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Align");
	G2antt1.HeaderAppearance = 1;
	G2antt1.ScrollBySingleLine = true;
	G2antt1.DrawGridLines = -2;
	var var_Chart = G2antt1.Chart;
		var_Chart.DrawGridLines = -2;
		var_Chart.FirstVisibleDate = "12/23/2000";
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(false) = 128;
		var var_Bar = var_Chart.Bars.Item("Task");
			var_Bar.Pattern = 32;
			var_Bar.Color = 10790052;
			var_Bar.StartColor = 15790320;
			var_Bar.EndColor = var_Bar.StartColor;
			var_Bar.Height = 15;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("default");
		var_Items.AddBar(h,"Task","12/22/2000","12/27/2000","","label");
		var_Items.ItemBar(h,"",4) = 1;
		h = var_Items.AddItem("default + 32");
		var_Items.AddBar(h,"Task","12/22/2000","12/27/2000","","label");
		var_Items.ItemBar(h,"",4) = 33;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2128
How do I set an extra data for each item
<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="MouseMove(Button,Shift,X,Y)" LANGUAGE="JScript">
	var i = G2antt1.ItemFromPoint(-1,-1,c,hit);
	alert( i );
	alert( G2antt1.Items.ItemData(i) );
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.ColumnAutoResize = true;
	G2antt1.Columns.Add("Default");
	var var_Items = G2antt1.Items;
		var_Items.ItemData(var_Items.AddItem("method 1")) = "your extra data of method 1";
		var_Items.InsertItem(0,"your extra data of method 2","method 2");
	var var_Items1 = G2antt1.Items;
		var_Items1.DefaultItem = var_Items1.AddItem("method 3");
		var_Items1.ItemData(0) = "your extra data of method 3";
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2127
Is it possible to show the position of rows the into the chart section

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="BeforeExpandItem(Item,Cancel)" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Indent = 16;
	G2antt1.LinesAtRoot = -1;
	G2antt1.HasLines = 1;
	G2antt1.DrawGridLines = 1;
	G2antt1.ScrollBySingleLine = true;
	G2antt1.FullRowSelect = 0;
	G2antt1.Columns.Add("Tasks");
	var var_Column = G2antt1.Columns.Add("Pos");
		var_Column.Visible = false;
		var_Column.FormatColumn = "`<r><bgcolor 000000><fgcolor FFFFFF> ` + 1 apos `` + ` </fgcolor></bgcolor>`";
		var_Column.Def(17) = 1;
	var var_Chart = G2antt1.Chart;
		var_Chart.ColumnsFormatLevel = ",|,1:64";
		var_Chart.FirstVisibleDate = "9/20/2006";
		var_Chart.ShowCollapsedBars = true;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(0) = 128;
		var_Chart.DrawGridLines = 1;
		var var_Bar = var_Chart.Bars.Item("Task");
			var_Bar.OverlaidType = 3;
			var_Bar.Color = 0;
			var_Bar.StartColor = 12895428;
			var_Bar.EndColor = 12895428;
			var_Bar.Pattern = 32;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Project 1");
		var h1 = var_Items.InsertItem(h,null,"Resources");
		var_Items.AddBar(h1,"Task","9/21/2006","9/25/2006","A",null);
		var_Items.AddBar(h1,"Task","9/24/2006","9/28/2006","B",null);
		var_Items.AddBar(h1,"Task","9/27/2006","9/29/2006","C",null);
		h = var_Items.AddItem("Project 2");
		h1 = var_Items.InsertItem(h,null,"Resources");
		var_Items.AddBar(h1,"Task","9/21/2006","9/25/2006","A",null);
		var_Items.AddBar(h1,"Task","9/24/2006","9/28/2006","B",null);
		var_Items.AddBar(h1,"Task","9/27/2006","9/29/2006","C",null);
		var_Items.ExpandItem(h) = true;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2126
I do not like to specify the item padding for every column I add. The question is how can I do it automatically

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.AttachTemplate("handle AddColumn(Column){Column{Def(48)=8;Def(49)=8;AllowDragging=False;AllowSizing = True}}");
	G2antt1.HeaderAppearance = 4;
	G2antt1.DrawGridLines = -1;
	G2antt1.GridLineStyle = 32;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Item");
		var var_Column = var_Columns.Add("Pos");
			var_Column.Position = 0;
			var_Column.Width = 32;
			var_Column.AllowSizing = false;
			var_Column.FormatColumn = "1 index ``";
	var var_Items = G2antt1.Items;
		var_Items.AddItem("Item A");
		var_Items.AddItem("Item B");
		var_Items.AddItem("Item C");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2125
Stack vs Cascade

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.ScrollBySingleLine = true;
	G2antt1.HeaderAppearance = 1;
	G2antt1.Columns.Add("Type");
	G2antt1.BackColorAlternate = 15790320;
	var var_Chart = G2antt1.Chart;
		var_Chart.LevelCount = 2;
		var_Chart.AllowCreateBar = 1;
		var_Chart.AllowLinkBars = false;
		var_Chart.ResizeUnitScale = 65536;
		var_Chart.PaneWidth(false) = 128;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.Bars.Copy("Task","Stack").OverlaidType = 3;
		var_Chart.Bars.Copy("Task","AStack").OverlaidType = 515;
		var_Chart.Bars.Copy("Task","Cascade").OverlaidType = 4;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Stack");
		var_Items.AddBar(h,"Stack","1/2/2001","1/4/2001","A1",null);
		var_Items.AddBar(h,"Stack","1/3/2001","1/5/2001","A2",null);
		var_Items.AddBar(h,"Stack","1/4/2001","1/7/2001","A3",null);
		var_Items.AddBar(h,"Stack","1/2/2001","1/7/2001","A4",null);
		var_Items.AddBar(h,"Stack","1/8/2001","1/12/2001","A5",null);
		var_Items.AddItem(null);
		h = var_Items.AddItem("Stack-AutoArrange");
		var_Items.AddBar(h,"AStack","1/2/2001","1/4/2001","A1",null);
		var_Items.AddBar(h,"AStack","1/3/2001","1/5/2001","A2",null);
		var_Items.AddBar(h,"AStack","1/4/2001","1/7/2001","A3",null);
		var_Items.AddBar(h,"AStack","1/2/2001","1/7/2001","A4",null);
		var_Items.AddBar(h,"AStack","1/8/2001","1/12/2001","A5",null);
		var_Items.AddItem(null);
		h = var_Items.AddItem("Cascade");
		var_Items.AddBar(h,"Cascade","1/2/2001","1/4/2001","A1",null);
		var_Items.AddBar(h,"Cascade","1/3/2001","1/5/2001","A2",null);
		var_Items.AddBar(h,"Cascade","1/4/2001","1/7/2001","A3",null);
		var_Items.AddBar(h,"Cascade","1/2/2001","1/7/2001","A4",null);
		var_Items.AddBar(h,"Cascade","1/8/2001","1/12/2001","A5",null);
		var_Items.AddItem(null);
		var_Items.ItemBar(0,"<*>",3) = "<%=%9%>";
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2124
How can I change the Exclude field in the drop down filter window

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.LinesAtRoot = -1;
	G2antt1.HTMLPicture("exclude") = "gCJKBOI4NBQaBQAhQNJJIIhShQACERCAEAcRdrdcUQhQDOZCJJUBEjbbhJ7giIJOBILJziJvl4BeKibhDiIZOhFLB0KZvMx0O5hORlAB3owuNJuNZzMZhOBlFxvORnT" +
	"buHgaiIeKBMKhFf9fDIcEoPCAVEAlGI4HhBBYMCARCQVGg4IhVMCAWC2XY1Q7WJ8RBB0KROKYAYDBbzicjndD6fA/VsRHRJIhBkRbMYIGwGAQjA2fRYOEBoYjBFBx1AT" +
	"CgCGQ8M7OTjSaJMDRDKIwYu5DrIMBgSAADKJTqhBhyRApAA3FAucZPPilokRJJFJxEVxCMCCgIA==";
	G2antt1.Description(25) = "<img>exclude</img>";
	var var_Column = G2antt1.Columns.Add("Items");
		var_Column.DisplayFilterButton = true;
		var_Column.DisplayFilterPattern = false;
		var_Column.FilterList = 9472;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Root 1");
		var_Items.InsertItem(h,null,"Child 1");
		var_Items.InsertItem(h,null,"Child 2");
		var_Items.ExpandItem(h) = true;
		h = var_Items.AddItem("Root 2");
		var_Items.InsertItem(h,null,"Child 1");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2123
How can I change the Exclude field in the drop down filter window

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.LinesAtRoot = -1;
	G2antt1.Description(25) = "<bgcolor 0><fgcolor ffffff> Exclude </fgcolor></bgcolor>";
	var var_Column = G2antt1.Columns.Add("Items");
		var_Column.DisplayFilterButton = true;
		var_Column.DisplayFilterPattern = false;
		var_Column.FilterList = 9472;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Root 1");
		var_Items.InsertItem(h,null,"Child 1");
		var_Items.InsertItem(h,null,"Child 2");
		var_Items.ExpandItem(h) = true;
		h = var_Items.AddItem("Root 2");
		var_Items.InsertItem(h,null,"Child 1");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2122
The grid lines looks different then before. What should I do

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.LinesAtRoot = -1;
	var var_Column = G2antt1.Columns.Add("Tasks");
		var_Column.Def(0) = true;
		var_Column.PartialCheck = true;
	G2antt1.DrawGridLines = -1;
	G2antt1.GridLineStyle = 512;
	G2antt1.Chart.DrawGridLines = G2antt1.DrawGridLines;
	G2antt1.Chart.GridLineStyle = G2antt1.GridLineStyle;
	G2antt1.HeaderVisible = 1;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Project");
		var hChild = var_Items.InsertItem(h,null,"Task 1");
		var_Items.SelectItem(hChild) = true;
		hChild = var_Items.InsertItem(h,null,"Task 2");
		var_Items.CellState(hChild,0) = 1;
		hChild = var_Items.InsertItem(h,null,"Task 3");
		var_Items.CellState(hChild,0) = 1;
		var_Items.ExpandItem(h) = true;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2121
How can I hide the task/bar's extra-caption

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Chart = G2antt1.Chart;
		var_Chart.PaneWidth(false) = 96;
		var_Chart.FirstVisibleDate = "1/1/2011";
		var var_Bar = var_Chart.Bars.Item("Task");
			var_Bar.Def(44) = "<%=%C0%>";
			var_Bar.Def(4) = 18;
			var_Bar.Def(45) = 16;
	G2antt1.Columns.Add("Task");
	var var_Column = G2antt1.Columns.Add("Show");
		var var_Editor = var_Column.Editor;
			var_Editor.EditType = 19;
			var_Editor.Option(17) = 1;
		var_Column.Def(18) = 57;
	var var_Items = G2antt1.Items;
		var_Items.AllowCellValueToItemBar = true;
		var_Items.AddBar(var_Items.AddItem("Task 1"),"Task","1/3/2011","1/7/2011",null,null);
		var_Items.ItemBar(var_Items.FirstVisibleItem,"",57) = false;
		var_Items.AddBar(var_Items.AddItem("Task 2"),"Task","1/4/2011","1/8/2011",null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2120
How can I hide the task/bar's caption

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Chart = G2antt1.Chart;
		var_Chart.PaneWidth(false) = 96;
		var_Chart.FirstVisibleDate = "1/1/2011";
		var var_Bar = var_Chart.Bars.Item("Task");
			var_Bar.Def(3) = "<%=%C0%>";
			var_Bar.Def(4) = 18;
	G2antt1.Columns.Add("Task");
	var var_Column = G2antt1.Columns.Add("Show");
		var var_Editor = var_Column.Editor;
			var_Editor.EditType = 19;
			var_Editor.Option(17) = 1;
		var_Column.Def(18) = 56;
	var var_Items = G2antt1.Items;
		var_Items.AllowCellValueToItemBar = true;
		var_Items.AddBar(var_Items.AddItem("Task 1"),"Task","1/3/2011","1/7/2011",null,null);
		var_Items.ItemBar(var_Items.FirstVisibleItem,"",56) = false;
		var_Items.AddBar(var_Items.AddItem("Task 2"),"Task","1/4/2011","1/8/2011",null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2119
Can I sort the column by check-state

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Column = G2antt1.Columns.Add("Check");
		var_Column.Def(0) = true;
		var_Column.SortType = 32;
	var var_Items = G2antt1.Items;
		var_Items.AddItem(null);
		var_Items.CellState(var_Items.AddItem(null),0) = 1;
		var_Items.CellState(var_Items.AddItem(null),0) = 1;
		var_Items.AddItem(null);
	G2antt1.Columns.Item(0).SortOrder = 1;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2118
Can I sort the column by image

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Images("gBJJgBAIDAAGAAEAAQhYAf8Pf4hh0QihCJo2AEZjQAjEZFEaIEaEEaAIAkcbk0olUrlktl0vmExmUzmk1m03nE5nU7nk9n0/oFBoVDolFo1HpFJpVLplNp1PqFRqVTq" +
	"lVq1XrFZrVbrldr1fsFhsVjslls1ntFptVrtltt1vuFxuVzul1u13vF5vV7vl9v1/wGBwWDwmFw2HxGJxWLxmNx0xiFdyOTh8Tf9ZymXx+QytcyNgz8r0OblWjyWds+m" +
	"0ka1Vf1ta1+r1mos2xrG2xeZ0+a0W0qOx3GO4NV3WeyvD2XJ5XL5nN51aiw+lfSj0gkUkAEllHanHI5j/cHg8EZf7w8vl8j4f/qfEZeB09/vjLAB30+kZQAP/P5/H6/y" +
	"NAOAEAwCjMBwFAEDwJBMDwLBYAP2/8Hv8/gAGAD8LQs9w/nhDY/oygIA=");
	var var_Column = G2antt1.Columns.Add("Image");
		var_Column.SortType = 48;
	var var_Items = G2antt1.Items;
		var_Items.CellImage(var_Items.AddItem(null),0) = 3;
		var_Items.AddItem(null);
		var_Items.CellImage(var_Items.AddItem(null),0) = 1;
		var_Items.CellImage(var_Items.AddItem(null),0) = 2;
	G2antt1.Columns.Item(0).SortOrder = 1;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2117
Can I sort the column by value(numeric)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Column = G2antt1.Columns.Add("Value");
		var_Column.Def(17) = 1;
		var_Column.FormatColumn = "`<fgcolor=808080><off 4><font ;6> ` + (1 index ``)  + ` </font></off></fgcolor>` + value";
		var_Column.SortType = 17;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("1");
		var_Items.AddItem("10");
		var_Items.AddItem("2");
		var_Items.AddItem("20");
	G2antt1.Columns.Item(0).SortOrder = 1;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2116
Can I sort a column by cell's state (checked, unchecked) rather than caption

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Column = G2antt1.Columns.Add("Check");
		var var_Editor = var_Column.Editor;
			var_Editor.EditType = 19;
			var_Editor.Option(17) = 1;
		var_Column.SortType = 1;
	var var_Items = G2antt1.Items;
		var_Items.AddItem(true);
		var_Items.AddItem(false);
		var_Items.AddItem(false);
		var_Items.AddItem(true);
	G2antt1.Columns.Item(0).SortOrder = 1;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2115
How can I highlight(bold) the items that displays milestones (method 2)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Tasks");
		var_Columns.Add("Start").Def(18) = 1;
		var_Columns.Add("End").Def(18) = 543;
		var var_Column = var_Columns.Add("Days");
			var_Column.Def(18) = 258;
			var_Column.FormatColumn = "value ? value : ``";
		var var_Column1 = var_Columns.Add("Type");
			var_Column1.Def(18) = 0;
			var_Column1.Visible = false;
	var var_ConditionalFormat = G2antt1.ConditionalFormats.Add("%4 = `Milestone`",null);
		var_ConditionalFormat.Bold = true;
		var_ConditionalFormat.Italic = true;
		var_ConditionalFormat.ApplyTo = -1;
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "9/20/2010";
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(0) = 256;
		var var_Bar = var_Chart.Bars.Add("Task:Split");
			var_Bar.Shortcut = "Task";
			var_Bar.Def(20) = true;
	var var_Items = G2antt1.Items;
		var_Items.AllowCellValueToItemBar = true;
		var_Items.AddBar(var_Items.AddItem("M1"),"Milestone","9/24/2010","9/24/2010",null,null);
		var_Items.AddBar(var_Items.AddItem("T1"),"Task","9/24/2010","9/28/2010",null,null);
		var_Items.AddBar(var_Items.AddItem("T2"),"Task","9/27/2010","9/28/2010",null,null);
		var_Items.AddBar(var_Items.AddItem("M3"),"Milestone","9/28/2010","9/28/2010",null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2114
How can I highlight(bold) the items that displays milestones (method 1)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Tasks");
		var_Columns.Add("Start").Def(18) = 1;
		var_Columns.Add("End").Def(18) = 543;
		var var_Column = var_Columns.Add("Days");
			var_Column.Def(18) = 258;
			var_Column.FormatColumn = "value ? value : ``";
	var var_ConditionalFormat = G2antt1.ConditionalFormats.Add("%3 = 0",null);
		var_ConditionalFormat.Bold = true;
		var_ConditionalFormat.Italic = true;
		var_ConditionalFormat.ApplyTo = -1;
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "9/20/2010";
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(0) = 256;
		var var_Bar = var_Chart.Bars.Add("Task:Split");
			var_Bar.Shortcut = "Task";
			var_Bar.Def(20) = true;
	var var_Items = G2antt1.Items;
		var_Items.AllowCellValueToItemBar = true;
		var_Items.AddBar(var_Items.AddItem("M1"),"Milestone","9/24/2010","9/24/2010",null,null);
		var_Items.AddBar(var_Items.AddItem("T1"),"Task","9/24/2010","9/28/2010",null,null);
		var_Items.AddBar(var_Items.AddItem("T2"),"Task","9/27/2010","9/28/2010",null,null);
		var_Items.AddBar(var_Items.AddItem("M3"),"Milestone","9/28/2010","9/28/2010",null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2113
Bars with gradient shows no border or frame arround. What can be done (method 2)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Task");
	G2antt1.Chart.FirstVisibleDate = "1/1/2001";
	G2antt1.Chart.PaneWidth(false) = 48;
	G2antt1.DefaultItemHeight = 24;
	var var_Bar = G2antt1.Chart.Bars.Add("E1");
		var_Bar.Color = 0;
		var_Bar.StartColor = 65280;
		var_Bar.EndColor = 65535;
		var_Bar.Pattern = 96;
		var_Bar.Height = 20;
	var var_Bar1 = G2antt1.Chart.Bars.Add("E2");
		var_Bar1.Color = 0;
		var_Bar1.StartColor = 65280;
		var_Bar1.EndColor = 65535;
		var_Bar1.Pattern = 96;
		var_Bar1.Height = 20;
		var_Bar1.Def(53) = "[frame=RGB(255,0,0),framethick]";
	var var_Items = G2antt1.Items;
		var_Items.AddItem(null);
		var h = var_Items.AddItem("no border");
		var_Items.AddBar(h,"E1","1/2/2001","1/8/2001","",null);
		h = var_Items.AddItem("w/h boder");
		var_Items.AddBar(h,"E2","1/2/2001","1/8/2001","",null);
		var_Items.AddItem(null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2112
Bars with gradient shows no border or frame arround. What can be done (method 1)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Task");
	G2antt1.Chart.FirstVisibleDate = "1/1/2001";
	G2antt1.Chart.PaneWidth(false) = 48;
	G2antt1.DefaultItemHeight = 24;
	var var_Bar = G2antt1.Chart.Bars.Add("E2");
		var_Bar.Color = 0;
		var_Bar.StartColor = 65280;
		var_Bar.EndColor = 65535;
		var_Bar.Pattern = 96;
		var_Bar.Height = 20;
	var var_Items = G2antt1.Items;
		var_Items.AddItem(null);
		var h = var_Items.AddItem("no border");
		var_Items.AddBar(h,"E2","1/2/2001","1/8/2001","",null);
		h = var_Items.AddItem("w/h boder");
		var_Items.AddBar(h,"E2","1/2/2001","1/8/2001","",null);
		var_Items.ItemBar(h,"",53) = "[frame=RGB(255,0,0),framethick]";
		var_Items.AddItem(null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2111
Is it possible to display auto-numbers (rows-numbers) for non-empty items only

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Chart.PaneWidth(false) = 128;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Items");
		var var_Column = var_Columns.Add("Pos");
			var_Column.FormatColumn = "len(%C0) ? 1 pos `` : ``";
			var_Column.Position = 0;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("Item A");
		var_Items.AddItem("");
		var_Items.AddItem("Item B");
		var_Items.AddItem("");
		var_Items.AddItem("Item C");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2110
Is it possible to separate the group of items using horizontal-lines (root-items)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.VisualAppearance.Add(1,"gBFLBCJwBAEHhEJAAEhABLEIQAAYAQGKIcBiAKBQAGaAoDgYN4MAANAwjJBMKgBBCLIxhEYobgmGIaRiAUbQSKEPxLEiPmqSHIEWwtDiBZgieTpNhAMg1CTNU4RAKoY" +
	"RzBKeZ7kGZIVjKMofURRDpxBBMAkB");
	G2antt1.LinesAtRoot = -1;
	G2antt1.DefaultItemHeight = 24;
	G2antt1.SelBackMode = 1;
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(false) = 196;
		var_Chart.SelBackColor = G2antt1.SelBackColor;
	var var_Columns = G2antt1.Columns;
		var var_Column = var_Columns.Add("Default");
			var_Column.Def(0) = true;
			var_Column.PartialCheck = true;
		var var_Column1 = var_Columns.Add("Position");
			var_Column1.FormatColumn = "1 + ((1 rpos ``) contains `.`)";
			var_Column1.Visible = false;
	var var_ConditionalFormat = G2antt1.ConditionalFormats.Add("%C1",null);
		var_ConditionalFormat.BackColor = 16777216;
		var_ConditionalFormat.ChartBackColor = var_ConditionalFormat.BackColor;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Group 1");
		var_Items.AddBar(var_Items.InsertItem(h,null,"Child 1"),"Task","1/3/2001","1/13/2001",null,null);
		var_Items.AddBar(var_Items.InsertItem(h,null,"Child 2"),"Task","1/4/2001","1/14/2001",null,null);
		var_Items.ExpandItem(h) = true;
		h = var_Items.AddItem("Group 2");
		var_Items.AddBar(var_Items.InsertItem(h,null,"Child 1"),"Task","1/3/2001","1/13/2001",null,null);
		var_Items.AddBar(var_Items.InsertItem(h,null,"Child 2"),"Task","1/4/2001","1/14/2001",null,null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2109
How can specify a black pattern for the task

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.DefaultItemHeight = 22;
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(false) = 0;
	G2antt1.Columns.Add("Frames");
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Task");
		var_Items.AddBar(h,"Task","1/2/2001","1/12/2001","bar A",null);
		var_Items.ItemBar(h,"bar A",33) = 1;
		var_Items.AddBar(h,"Task","1/14/2001","1/24/2001","bar B",null);
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2108
Can I define a bar so it automatically fills the current item/row height (same height)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Task");
	var var_Chart = G2antt1.Chart;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(false) = 96;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.Bars.Item("Task").Height = -1;
	var var_Items = G2antt1.Items;
		var_Items.AddBar(var_Items.AddItem("Task A"),"Task","1/2/2001","1/5/2001",null,null);
		var h = var_Items.AddItem("Task A");
		var_Items.AddBar(h,"Task","1/2/2001","1/5/2001","",null);
		var_Items.ItemBar(h,"",33) = 255;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2107
How can I highlight a specified date for the entire chart (Method 2)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Tasks");
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.PaneWidth(false) = 96;
		var_Chart.UnitWidth = 18;
		var_Chart.LevelCount = 2;
		var_Chart.MarkTimeZone("zone1","1/8/2001","1/9/2001",0,null);
		var_Chart.MarkTimeZone("zone2","1/2/2001","1/4/2001",0,"50");
	var var_Items = G2antt1.Items;
		var_Items.AddItem("");
		var h = var_Items.AddItem("Task(I)");
		var_Items.AddBar(h,"Task","1/5/2001","1/12/2001","I",null);
		var_Items.AddItem("");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2106
How can I highlight a specified date for the entire chart, including the header (Method 1)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Tasks");
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.PaneWidth(false) = 96;
		var_Chart.UnitWidth = 18;
		var_Chart.LevelCount = 2;
		var_Chart.AllowInsideZoom = true;
		var_Chart.AllowResizeInsideZoom = false;
		var_Chart.InsideZoomOnDblClick = false;
		var var_InsideZoomFormat = var_Chart.DefaultInsideZoomFormat;
			var_InsideZoomFormat.ForeColor = 16777215;
			var_InsideZoomFormat.BackColorChart = 65536;
			var_InsideZoomFormat.BackColor = 65536;
		var var_InsideZooms = var_Chart.InsideZooms;
			var_InsideZooms.SplitBaseLevel = false;
			var_InsideZooms.DefaultWidth = 18;
			var_InsideZooms.Add("1/8/2001").AllowInsideFormat = false;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("");
		var h = var_Items.AddItem("Task(I)");
		var_Items.AddBar(h,"Task","1/5/2001","1/12/2001","I",null);
		var_Items.AddItem("");
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2105
How can I highlight a specified date of a specified item

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Tasks");
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.PaneWidth(false) = 96;
		var_Chart.UnitWidth = 18;
		var_Chart.LevelCount = 2;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("");
		var h = var_Items.AddItem("Task(D)");
		var_Items.AddBar(h,"Task","1/5/2001","1/12/2001","D",null);
		var_Items.AddItem("");
	var var_Notes = G2antt1.Chart.Notes;
		var var_Note = var_Notes.Add("NoteD",h,"1/8/2001","<b><%dd%></b><br><%m%><br><%yy%>");
			var_Note.PartFixedWidth(1) = 18;
			var_Note.PartShadow(1) = false;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2104
How can I display the start/end of the task within its margins (notes)

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Columns.Add("Tasks");
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "1/1/2001";
		var_Chart.PaneWidth(false) = 96;
		var_Chart.UnitWidth = 18;
		var_Chart.LevelCount = 2;
	var var_Items = G2antt1.Items;
		var_Items.AddItem("");
		var h = var_Items.AddItem("Task(T)");
		var_Items.AddBar(h,"Task","1/5/2001","1/12/2001","T",null);
		var_Items.AddItem("");
	var var_Notes = G2antt1.Chart.Notes;
		var var_Note = var_Notes.Add("NoteTS",h,"T","");
			var_Note.ShowLink = 0;
			var_Note.PartText(0) = "<%d%>";
			var_Note.PartHOffset(0) = 9;
			var_Note.PartFixedWidth(0) = 18;
		var var_Note1 = var_Notes.Add("NoteTE",h,"T","");
			var_Note1.RelativePosition = "E-1";
			var_Note1.ShowLink = 0;
			var_Note1.PartText(0) = "<%d%>";
			var_Note1.PartHOffset(0) = 9;
			var_Note1.PartFixedWidth(0) = 18;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2103
Is it possible to show the tasks not-overlaid when the item is collapsed and overlaid once the user expands the item

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="BeforeExpandItem(Item,Cancel)" LANGUAGE="JScript">
	G2antt1.Refresh();
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.Indent = 16;
	G2antt1.LinesAtRoot = -1;
	G2antt1.HasLines = 1;
	G2antt1.DrawGridLines = 1;
	G2antt1.Columns.Add("Tasks");
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstVisibleDate = "9/20/2006";
		var_Chart.ShowCollapsedBars = true;
		var_Chart.LevelCount = 2;
		var_Chart.PaneWidth(0) = 128;
		var_Chart.DrawGridLines = 1;
		var var_Bar = var_Chart.Bars.Item("Task");
			var_Bar.OverlaidType = 3;
			var_Bar.Color = 0;
			var_Bar.StartColor = 12895428;
			var_Bar.EndColor = 12895428;
			var_Bar.Pattern = 32;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Project 1");
		var h1 = var_Items.InsertItem(h,null,"Resources");
		var_Items.AddBar(h1,"Task","9/21/2006","9/25/2006","A",null);
		var_Items.AddBar(h1,"Task","9/24/2006","9/28/2006","B",null);
		var_Items.AddBar(h1,"Task","9/27/2006","9/29/2006","C",null);
		h = var_Items.AddItem("Project 2");
		h1 = var_Items.InsertItem(h,null,"Resources");
		var_Items.AddBar(h1,"Task","9/21/2006","9/25/2006","A",null);
		var_Items.AddBar(h1,"Task","9/24/2006","9/28/2006","B",null);
		var_Items.AddBar(h1,"Task","9/27/2006","9/29/2006","C",null);
		var_Items.ExpandItem(h) = true;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2102
Is it possible to display the label of the level without truncating / no clip

<BODY onload="Init()">
<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	var var_Chart = G2antt1.Chart;
		var_Chart.FirstWeekDay = 0;
		var_Chart.FirstVisibleDate = "12/31/2000";
		var_Chart.PaneWidth(0) = 0;
		var_Chart.LevelCount = 3;
		var var_Level = var_Chart.Level(0);
			var_Level.Label = 16;
			var_Level.FormatLabel = "`<c>` + value";
		var var_Level1 = var_Chart.Level(1);
			var_Level1.Label = 256;
			var_Level1.FormatLabel = "`<c>` + value";
		var var_Level2 = var_Chart.Level(2);
			var_Level2.Alignment = 256;
			var_Level2.FormatLabel = "weekday(dvalue) = 0 ? `<b>` + value : ``";
			var_Level2.DrawTickLines = 0;
			var_Level2.DrawTickLinesFrom(1,1);
			var_Level2.DrawGridLines = true;
		var_Chart.UnitWidth = 6;
		var_Chart.DrawGridLines = -1;
	G2antt1.EndUpdate();
}
</SCRIPT>
</BODY>

2101
How do I get the item's auto-number, when using FormatColumn property, as CellValue gets empty

<BODY onload="Init()">
<SCRIPT FOR="G2antt1" EVENT="SelectionChanged()" LANGUAGE="JScript">
	var var_Items = G2antt1.Items;
		alert( "pos: " );
		alert( var_Items.CellCaption(var_Items.FocusItem,1) );
		alert( "rpos(1): " );
		alert( var_Items.CellCaption(var_Items.FocusItem,2) );
		alert( "rpos(2): " );
		alert( var_Items.CellCaption(var_Items.FocusItem,3) );
		alert( "apos: " );
		alert( var_Items.CellCaption(var_Items.FocusItem,4) );
		alert( "index: " );
		alert( var_Items.CellCaption(var_Items.FocusItem,5) );
</SCRIPT>

<OBJECT CLASSID="clsid:CD481F4D-2D25-4759-803F-752C568F53B7" id="G2antt1"></OBJECT>

<SCRIPT LANGUAGE="JScript">
function Init()
{
	G2antt1.BeginUpdate();
	G2antt1.LinesAtRoot = -1;
	G2antt1.DrawGridLines = -2;
	G2antt1.HeaderAppearance = 4;
	var var_Columns = G2antt1.Columns;
		var_Columns.Add("Items");
		var var_Column = var_Columns.Add("pos");
			var_Column.FormatColumn = "1 pos ``";
			var_Column.Position = 0;
			var_Column.Width = 48;
			var_Column.AllowSizing = false;
		var var_Column1 = var_Columns.Add("rpos(1)");
			var_Column1.FormatColumn = "1 rpos ``";
			var_Column1.Position = 1;
			var_Column1.Width = 48;
			var_Column1.AllowSizing = false;
		var var_Column2 = var_Columns.Add("rpos(2)");
			var_Column2.FormatColumn = "1 rpos `.||A-Z`";
			var_Column2.Position = 2;
			var_Column2.Width = 48;
			var_Column2.AllowSizing = false;
		var var_Column3 = var_Columns.Add("apos");
			var_Column3.FormatColumn = "1 apos ``";
			var_Column3.Position = 3;
			var_Column3.Width = 48;
			var_Column3.AllowSizing = false;
		var var_Column4 = var_Columns.Add("index");
			var_Column4.FormatColumn = "1 index ``";
			var_Column4.Position = 4;
			var_Column4.Width = 48;
			var_Column4.AllowSizing = false;
	var var_Items = G2antt1.Items;
		var h = var_Items.AddItem("Item 1");
		var_Items.InsertItem(h,null,"Child 1");
		var hSel = var_Items.InsertItem(h,null,"Child 2");
		var_Items.ExpandItem(h) = true;
		var_Items.AddItem("Item 2");
		var_Items.AddItem("Item 3");
	G2antt1.EndUpdate();
	G2antt1.Items.SelectItem(hSel) = true;
}
</SCRIPT>
</BODY>